# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

10-091443

(43)Date of publication of application: 10.04.1998

(51)Int.CI.

G06F 9/42

G06F 9/30

G06F 9/46

(21)Application number : **09-135923** 

(71)Applicant: SEIKO EPSON CORP

(22)Date of filing:

08.05.1997

(72)Inventor: KUBOTA SATORU

**KUDO MAKOTO** 

**MIYAYAMA YOSHIYUKI** 

**SATO HISAO** 

(30)Priority

Priority number: 08127541

Priority date: 22.05.1996

Priority country: JP

(54) INFORMATION PROCESSING CIRCUIT, MICROCOMPUTER AND **ELECTRONIC EQUIPMENT** 



# (57)Abstract:

PROBLEM TO BE SOLVED: To efficiently describe a processing for dealing with a stack pointer with short instruction length, to efficiently describe the processings of execution, register saving and register restoration and to improve the processing speed of an interruption processing and sub-routine call return.

SOLUTION: CPU 10 decodes a stack pointer-only instruction group which contains a register SP14 only for the stack pointer and sets SP14 to be a mute operand by an instruction decoder 20. The stack pointer-only instruction group is executed in terms of hardware by using a generalpurpose register 11, PC12, SP14, an address adder 30, ALU 40 a PC incrementor 44, internal buses 72, 74, 76 and 78, internal signal lines 82, 84, 86 and 88 and external buses 92, 94, 96 and 98. The stack pointer-only instruction group contains an SP relative load instruction, a stack pointer shift instruction, a call instruction, a return instruction, a continuous push instruction and a continuous pop instruction.

#### LEGAL STATUS

[Date of request for examination] 12.12.2002

[Date of sending the examiner's decision of 01.06.2004

rejection]

[Kind of final disposal of application other than withdrawal the examiner's decision of rejection or

application converted registration]

[Date of final disposal for application] 20.07.2004

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

# \* NOTICES \*

JPO and NCIPI are not responsible for any

damages caused by the use of this translation.

- 1. This document has been translated by computer. So the translation may not reflect the original precisely.
- 2.\*\*\*\* shows the word which can not be translated.
- 3.In the drawings, any words are not translated.

#### **CLAIMS**

### [Claim(s)]

[Claim 1] The information-processing circuit characterized by to have the object code which makes an implied operand the stack-pointer dedicated register only used for stack pointers, and this stack-pointer dedicated register, to decode the object code of the instruction group only for stack pointers the processing based on this stack-pointer dedicated register was described to be, and to include a decode means output a control signal based on this object code, and an activation means perform said instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[Claim 2] In claim 1, said instruction group only for stack pointers includes the load instruction which has transfer register specific information in object code. When said decode means decodes said load instruction and said activation means executes said load instruction, Either [ at least ] the data transfer from the first area to the first given given register on memory, or the data transfer from said first given register to said first given area The information processing circuit characterized by carrying out based on the register address specified by the memory address specified with said stack-pointer dedicated register, and said transfer register specific information.

[Claim 3] The information processing circuit where the offset information said whose load instruction is the information about the offset for specifying the address of said first area on said memory is included in object code in claim 2, and said activation means is characterized by specifying said memory address using the contents and said offset information on said stackpointer dedicated register.

[Claim 4] In claim 3, said offset information includes the immediate offset information given by the immediate, and the data size information about the size of the given data on memory. Said activation means is based on said immediate offset information and said data size information. The information processing circuit which carries out the left logic shift of said immediate offset information, and is characterized by specifying said memory address with the value which generated the offset value and added the contents and said offset value of said stack-pointer dedicated register.

[Claim 5] The information-processing circuit characterized by to change the contents of said stack-pointer dedicated register based on said migration information in case said decode means decodes said stack-pointer migration instruction and said activation means executes said stack-pointer migration instruction including a stack-pointer migration instruction for said instruction group only for stack pointers to have migration information in object code, and move a stack pointer to it in either claim 1 - claim 4.

[Claim 6] The information processing circuit where said instruction-execution means is

characterized by processing at least one side of the processing which subtracts said immediate migration information from the contents of the processing adding said immediate migration information and contents of said stack-pointer dedicated register, and said stack-pointer dedicated register in claim 5 including the immediate migration information that said migration information was given by the immediate.

[Claim 7] In either claim 1 - claim 6, two or more registers which were able to be continuously set in order are included. Said instruction group only for stack pointers includes either [ at least ] the continuation push instruction which has two or more register specific information in object code, or a continuation pop instruction. Said decode means decodes either [ at least ] said continuation push instruction or a continuation pop instruction. When said instruction-execution means executes either [ at least ] said continuation push instruction or said continuation pop instruction, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack The information processing circuit characterized by attaining to the memory address specified according to the contents of said stack-pointer dedicated register, and carrying out based on said two or more register specific information.

[Claim 8] In claim 7, n general-purpose registers specified by the register numbers from 0 to n-1 are included. One [ at least ] object code of said continuation push instruction and a continuation pop instruction as said two or more register specific information The last register number as which either of said register numbers was specified is included. At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing in which said activation means carries out a multiple-times push continuously to the stack prepared in memory from two or more registers to the register specified by said last register number from a register 0, and said stack The information processing circuit characterized by carrying out based on the memory address specified according to the contents of said stackpointer dedicated register.

[Claim 9] In claim 7 or either of 8 said activation means the contents of the either given register of two or more of said registers The write-in means written in the stack prepared in memory based on the memory address specified with said stack-pointer dedicated register, A count count means of writing to count the count of writing to said stack by said write-in means, A comparison means to compare the value of said count of writing counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said write-in means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place, It controls so that the first input of said adder serves as the contents of the stack-pointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the write-in address-generation means after it 1 input-control means controlled to write in and to become the address, The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of the register specified with the value which subtracted said count of writing from said two or more register specific information The information processing circuit characterized by controlling two or more writing to said stack from a register and write-in termination based on the comparison result of said comparison means including the means written in said stack based on said write-in memory address.

[Claim 10] The contents of the stack by which said instruction-execution means was formed in

memory in either of claims 7-9 based on the memory address specified with said stack-pointer dedicated register are read. A read-out means to store in the either given register of two or more of said registers, A count count means of read-out to count the count of read-out from said stack by said read-out means, A comparison means to compare the value of said count of read-out counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said read-out means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place, It controls so that the first input of said adder serves as the contents of the stackpointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the read-out address-generation means after it ] input-control means controlled to read and to become the address, The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of said stack are read based on said read-out memory address. The information processing circuit characterized by controlling read-out and read-out termination of the contents of said stack based on the comparison result of said comparison means including a read-out means to store in the register specified based on said count of writing.

[Claim 11] In either claim 1 - claim 10, the program counter register only for program counters is included. The branch instruction said whose instruction groups only for stack pointers are the instruction which branches to a subroutine, and a return instruction from said subroutine is included. When said decode means decodes said branch instruction and said instruction-execution means executes said branch instruction, At least one side of the return to shunting of the contents of said program counter register to the second given area of the stack prepared in memory, and the program counter register of the contents of said second area The information processing circuit characterized by including the means performed based on the memory address specified with said stack-pointer dedicated register, and a means to update the contents of said stack-pointer dedicated register based on said shunting and said return.

[Claim 12] It is an information processing circuit containing the stack pointer assigned to two or more registers which were able to be continuously set in order, and one of general-purpose registers. The object code of one [ at least ] instruction of the continuation push instruction which has two or more register specific information in object code, and a continuation pop instruction is decoded. When at least one side of a means to output a control signal based on this object code, and said continuation push instruction and said continuation pop instruction is performed, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack The information processing circuit characterized by including the means performed based on the memory address specified according to the contents of said control signal and said stack-pointer dedicated register, and said two or more register specific information.

[Claim 13] The information processing circuit characterized by being a RISC method in either claim 1 - claim 12.

[Claim 14] The information processing circuit characterized by decoding a fixed-length instruction and performing executive operation in either claim 1 - claim 13 based on this instruction.

[Claim 15] The microcomputer characterized by including a means to perform I/O with an information processing circuit, a storage means, and the exterior according to claim 1 to 14. [Claim 16] The microcomputer characterized by performing the program of the language which

has the structure where relate with said stack pointer and the storage region of an auto variable is secured in claim 15.

[Claim 17] Electronic equipment characterized by including the microcomputer indicated by claim 15 or either of 16.

# **DETAILED DESCRIPTION**

[Detailed Description of the Invention]

[0001]

[Field of the Invention] This invention relates to the electronic equipment constituted using the microcomputer which contains an information processing circuit and said information processing circuit, and this microcomputer.

[0002]

Background Art and Problem(s) to be Solved by the Invention] Conventionally, in the microcomputer of a RISC method which can process 32-bit data, the fixed-length instruction of 32-bit width of face was used. The reason is that the time amount which decoding of an instruction takes can be shortened compared with the case where a variable-length instruction is used, and it can make the circuit scale of a microcomputer small if a fixed-length instruction is used.

[0003] However, also in a 32-bit microcomputer, there are also many instructions which are not needed especially 32 bits. Therefore, if 32 bits describes all instructions, the instructions which a redundant part produces in an instruction will increase in number, and the utilization ratio of memory will worsen.

[0004] then, this invention -- the person was performing examination about the microcomputer which processes the fixed-length instruction of bit width of face shorter than the bit width of face of the data which can be processed in order to raise the utilization ratio of memory, without complicating a control circuit.

[0005] However, if 32 bit fixed length's instruction is only made into a 16-bit fixed length, for example, the following troubles will arise.

[0006] That is, in the microcomputer of a RISC method, in order to think the versatility of processing and an instruction set as important, when processing which deals with a stack pointer was performed, said processing was performed using the instruction which makes a general-purpose register applicable to actuation, using one of general-purpose registers as a stack pointer. Therefore, assignment of the general-purpose register currently used as a stack pointer is needed for that of said instruction at the time of describing such processing.

[0007] For example, when the instruction which makes a general-purpose register applicable to actuation describes the processing which transmits the data specified by the memory address which applied the given offset value to the stack pointer to a given register, said offset value, the information which specifies said given register, and the information which specifies the register currently used as a stack pointer are needed for the object code of the instruction.

[0008] Thus, since the information specified by object code increases when describing the processing which deals with a stack pointer with the instruction which makes a general-purpose register applicable to actuation, it becomes difficult to describe the contents of the instruction by the 16-bit fixed length. Also especially into an instruction, if an instruction length is made into 32 bits here, since an instruction also has many instructions which are not needed 32 bits, the

instructions which produce a redundant part will increase in number, and aggravation of the utilization ratio of memory will be invited to an instruction.

[0009] Moreover, since the memory which stores it is also too much needed if an instruction length becomes long, it is desirable that not only a fixed-length instruction but an instruction length can be shortened from a viewpoint of efficient use of memory.

[0010] Moreover, since the instructions which deal with a stack pointer increase in number when performing the program described in the language in which it relates with a stack pointer, for example like C, and the storage region of an auto variable is secured, it is desirable to describe efficiently the instruction which deals with a stack pointer, and to perform it.

[0011] Then, when processing which deals with a stack pointer was performed, by the shortest possible instruction length, the contents of an instruction were described and architecture which can be performed was desired.

[0012] Moreover, especially CPU of a RISC method came to have many general-purpose registers in the interior in order [ latest ] to raise the engine performance. It is because many processings are made to a high speed inside CPU, without accessing memory by having many registers in the interior. Thus, if it has many internal registers, the number of registers which should be evacuated will increase in the case of interruption processing or processing of the register evacuation at the time of a subroutine call, and restoration.

[0013] The conventional example is explained taking the case of shunting of the register which uses it abundantly in case going into a subroutine also in a stack system instruction \*\*\*\* is sufficient hereafter and it carries out, and return instruction.

[0014] Usually, the instruction set of a microcomputer shunts to the stack which prepared the register of CPU in memory, or has the instruction for restoring. There is a thing with an instruction of dedication for that or a thing with a register indirect-addressing instruction. [0015] As a technique about the instruction for [ said ] shunting or restoring, "80386 Pro gramine" (John H.Crawford Patric P.Gelsigner work Iwatani \*\* translation) has the following description about 80386 of Intel.

[0016] That is, it is an instruction which writes a register in a stack. There are push, pusha, and pushad and there are pop, popa, and popad as an instruction for returning data to a register from a stack.

[0017] When writing a register in a stack with a push instruction push EAX A register is specified as an operand like. This is the case of the 32-bit register EAX. It is push when writing Registers EAX, ECX, EDX, and EBX to a stack altogether. EAXpush ECXpush EDXpush A push instruction is repeated like EBX.

[0018] Thus, if it is operating one register at a time with push and a pop instruction, the size of object code will become large, and a program execution step will also increase, therefore program execution time amount and processing actuation will become slower.

[0019] then, all eight general-purpose registers that 80386 has -- a stack -- writing in -- pusha or - pushad An instruction is used. pusha targets the 16 bit register of low order of each of eight registers 32 bits for pushad. It is omissible to repeat a push instruction 8 times by pusha and pushad.

[0020] The same is said of pop, popa, and a popad instruction.

[0021] In order to fetch the disadvantageous point of repeating a push instruction that a program code becomes long and the whole instruction and to perform it, it is that activation is slow. This point is greatly improved by said pusha and pushad, when writing all of said eight registers in a stack. However, when writing in less than eight register like the case of four, or the case of six,

this point does not improve.

[0022] That is, also when all registers are operated with pusha, pushad, popa, and a popad instruction like 80386 and there is no need of evacuating and restoring all the registers, the late long instruction of this cycle must be used. In such a case, although an instruction can be managed with one instruction, the problem of becoming long produces the execution cycle of this instruction.

[0023] Moreover, in case it branches to a subroutine by a call instruction, a return instruction, etc. or returns to the called routine, shunting of a program counter and the restorative processing which are needed as the return point address are needed. In CPU of the conventional RISC method, these processings were realized by software. That is, shunting of said program counter and restorative processing were performed by executing assembler instruction (object code) which described this processing. For this reason, the call instruction and the return instruction caused the increment in object code, and in order to fetch the whole instruction and to perform, they had caused slowdown of execution speed.

[0024] The purpose of this invention is offering the information processing circuit which has the architecture which can describe efficiently the processing which deals with a stack pointer by the short instruction length, and can perform it, a microcomputer, and electronic equipment. [0025] Again Other purposes of this invention are describing processing of register evacuation or register restoration efficiently, and offering interruption processing and the information processing circuit where the processing speed of a subroutine call return is quick, a microcomputer, and electronic equipment.

[0026]

[Means for Solving the Problem] This invention is characterized by to have the object code which makes an implied operand the stack-pointer dedicated register only used for stack pointers, and this stack-pointer dedicated register, to decode the object code of the instruction group only for stack pointers the processing based on this stack-pointer dedicated register was described to be, and to include a decode means output a control signal based on this object code, and an activation means perform said instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[0027] Although the thing of the program code obtained as a result of translating object code into an absolute language by the compiler generally in here is said, in this invention, it is used with the large concept which contains the program code described in the absolute language not related in the paddle by the compiler.

[0028] The information processing circuit of this invention has a stack-pointer dedicated register only for stack pointers, and it is constituted so that decode of the instruction group only for stack pointers which makes this stack-pointer dedicated register applicable to actuation, and activation may be performed.

[0029] Since said instruction group only for stack pointers has the operation code of the dedication for dealing with a stack-pointer dedicated register, it does not need the information for specifying a stack pointer for the operand of object code. In other words, said instruction group only for stack pointers makes the stack-pointer dedicated register the implied operand. For this reason, compared with the case where a stack pointer is operated using the instruction which makes one of the general-purpose registers addressing to a rate, and makes a general-purpose register applicable to actuation at a stack pointer, the instruction which deals with a stack pointer by the short instruction length can be described.

[0030] Therefore, according to this invention, the information processing circuit which can

describe and perform processing which deals with a stack pointer by the short instruction length can be offered. Moreover, the good information processing circuit of the utilization ratio of the memory which memorizes an instruction can be offered.

[0031] This invention includes the load instruction to which said instruction group only for stack pointers has transfer register specific information in object code. When said decode means decodes said load instruction and said activation means executes said load instruction, Either [ at least ] the data transfer from the first area to the first given given register on memory, or the data transfer from said first given register to said first given area It is characterized by carrying out based on the register address specified by the memory address specified with said stack-pointer dedicated register, and said transfer register specific information.

[0032] Said load instruction included in said instruction group only for stack pointers in here is an instruction which performs a data transfer between memory and a register, and is a concept including either [ at least ] the transfer to a register from memory, or the transfer to memory from a register. In addition, it is the concept which also contains address data regardless of the contents of data. A memory address means the address for pinpointing the area on the memory in the case of a transfer.

[0033] Since said load instruction has the operation code of the dedication for making a stack-pointer dedicated register applicable to actuation, it does not need the information for specifying a stack pointer for the operand of object code. For this reason, when making data transfer processing perform between the area on the memory which has the memory address related with the stack pointer, and a register, a short instruction length can describe.

[0034] This invention includes the offset information said whose load instruction is the information about the offset for specifying the address of said first area on said memory in object code, and said activation means is characterized by specifying said memory address using the contents and said offset information on said stack-pointer dedicated register.

[0035] In here, what specified the offset value by the direct immediate is sufficient as offset information, and the case where it specifies indirectly like [ in the case of specifying the addresses, such as a register with which the offset value was stored ] is sufficient as it. When said load instruction including offset information is executed, said memory address which is needed in case it is a transfer is specified based on the contents and offset information on a stack-pointer dedicated register.

[0036] Therefore, when making data transfer processing perform between the area on the memory which has the memory address specified based on a stack pointer and said offset information, and a register, a short instruction length can describe.

[0037] Moreover, according to this invention, also in the information processing circuit of the structure where a stack pointer always puts the word boundary, for example, it becomes possible by specifying suitable offset information to specify the area of the arbitration on a stack. For this reason, according to the size of data, it can store in a stack efficiently, and improvement in the utilization ratio of a stack can be aimed at.

[0038] Including the immediate offset information that said offset information was given by the immediate, and the data size information about the size of the given data on memory, based on said immediate offset information and said data size information, said activation means carries out the left logic shift of said immediate offset information, and generates an offset value, and this invention is characterized by to specify said memory address with the value adding the contents and said offset value of said stack-pointer dedicated register.

[0039] In here, immediate offset information means what specified the offset value by the direct

immediate. Moreover, data size information means the size of the memory top data which should be transmitted. Usually, data size is expressed with 2n (n is three or more), such as 8-bit cutting tool data, and 16 bits halfword data, 32-bit WORD data. The address on memory is given per cutting tool, halfword data are set on a halfword boundary, and WORD data are set to the word boundary. Therefore, 1 bit of the low order of the memory address of halfword data is set to 0, and 2 bits of the low order of the memory address of WORD data are set to 00. Since the address of a stack pointer has pointed out the word boundary, 1 bit of the low order of the offset value in the case of generating the memory address of halfword data is set to 0, and 2 bits of the low order of the offset value in the case of generating the memory address of WORD data are set to 00.

[0040] Moreover, a left logic shift shifts the bit string of data on the left, and means the shift in which 0 goes into the vacancy bit (shift in bit) which comes out to the right-hand side of data by shift

[0041] According to this invention, since the left logic shift of said offset immediate information is performed based on data size, with data size, the bit of the low order decided uniquely can be omitted and immediate offset information can be described. Therefore, immediate offset information can be specified efficiently, and when it is data sizes other than a cutting tool, compared with the case where it specifies as it is, assignment becomes possible at a larger offset value.

[0042] Moreover, by using this instruction, the suitable boundary location according to the data size will be chosen at the time of the writing to the memory of data, and read-out. [0043] This invention is characterized by changing the contents of said stack-pointer dedicated register based on said migration information, in case said decode means decodes said stack-pointer migration instruction and said activation means executes said stack-pointer migration instruction including a stack-pointer migration instruction for said instruction group only for stack pointers to have migration information in object code, and move a stack pointer to it. [0044] Since said stack-pointer migration instruction has the operation code of the dedication for making a stack-pointer dedicated register applicable to actuation, it does not need the information for specifying a stack pointer for the operand of object code. For this reason, a short instruction length can describe to move a stack. Therefore, the amount of description of the instruction at the time of processing the data memorized by relating with the processing of data and the stack pointer which are stored in the stack is reducible.

[0045] Since migration of a stack can carry out easily according to this invention, it is effective when processing by securing stack area which is different in an especially different routine, respectively. That is, by performing processing to which a stack pointer is moved for every routine, it becomes addressable over a wide range field.

[0046] This invention is characterized by processing at least one side of the processing to which said instruction-execution means subtracts said immediate migration information from the contents of the processing adding said immediate migration information and contents of said stack-pointer dedicated register, and said stack-pointer dedicated register including the immediate migration information that said migration information was given by the immediate. [0047] According to this invention, only a part to have specified the value of a stack pointer for immediate migration information can describe the upper part or the processing to which it is made to move caudad by the short instruction length.

[0048] This invention contains two or more registers which were able to be continuously set in order. Said instruction group only for stack pointers Either [ at least ] the continuation push

instruction which has two or more register specific information in object code, or a continuation pop instruction is included. Said decode means decodes either [ at least ] said continuation push instruction or a continuation pop instruction. When said instruction-execution means executes either [ at least ] said continuation push instruction or said continuation pop instruction, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack It is characterized by attaining to the memory address specified according to the contents of said stack-pointer dedicated register, and carrying out based on said two or more register specific information. [0049] As for a push, taking out data from said stack as it is pop means accumulating and storing data in the stack prepared in memory. With the processing pushed in here, and the processing which carries out pop, said storing and processing of ejection, and an update process of the stack pointer accompanying it are included. The usual information processing circuit has the push instruction for storing data and the address in a stack from the register of 1, and the pop instruction which takes out the contents of the stack to a register. This push instruction and a pop instruction update the stack pointer accompanying an exchange of the data of a register and a stack, and this exchange.

[0050] Therefore, in exchanging data etc. by two or more registers and stacks, it is necessary to carry out multiple-times activation of these instructions.

[0051] However, according to this invention, if said continuation push instruction and said continuation pop instruction are executed, the same effectiveness as the case where multipletimes activation of the case where multiple-times activation of the push instruction is carried out continuously, or the pop instruction is carried out continuously will be acquired. That is, renewal of the stack pointer accompanying an exchange and this exchange of the data between two or more registers and a stack can be performed with one instruction. For this reason, when performing the data transfer between two or more registers and a stack, it can prevent object code size increasing by repeating a push instruction or a pop instruction. Moreover, improvement in the processing speed of interruption processing and a subroutine call return can be aimed at, without avoiding that a program execution step becomes long and consuming a useless cycle. [0052] This invention contains n general-purpose registers specified by the register numbers from 0 to n-1. One [ at least ] object code of said continuation push instruction and a continuation pop instruction as said two or more register specific information The last register number as which either of said register numbers was specified is included. At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing in which said activation means carries out a multiple-times push continuously to the stack prepared in memory from two or more registers to the register specified by said last register number from a register 0, and said stack It is characterized by carrying out based on the memory address specified according to the contents of said stack-pointer dedicated register. [0053] Usually, when there are two or more general-purpose registers, it has the address for specifying a register. By this invention, said register is specified by the register number followed from 0 to n-1.

[0054] According to this invention, either [ at least ] processing which pushes data between two or more registers and memory which were followed from a register 0 to said last register number, or processing which carries out pop is performed by specifying the register number of arbitration as said last register number. Therefore, in the program execution which has structure which uses a register in an order from the register of a register number 0, shunting and restoration of a

register can be performed efficiently.

[0055] The write-in means which writes the contents of the register of two or more of said registers either given [this invention] in said activation means in the stack prepared in memory based on the memory address specified with said stack-pointer dedicated register, A count count means of writing to count the count of writing to said stack by said write-in means. A comparison means to compare the value of said count of writing counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said write-in means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place, It controls so that the first input of said adder serves as the contents of the stack-pointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the write-in address-generation means after it ] input-control means controlled to write in and to become the address. The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of the register specified with the value which subtracted said count of writing from said two or more register specific information Based on the comparison result of said comparison means, it is characterized by controlling two or more writing to said stack from a register and write-in termination including the means written in said stack based on said write-in memory address. [0056] Moreover, this invention reads the contents of the stack by which said instructionexecution means was formed in memory based on the memory address specified with said stackpointer dedicated register. A read-out means to store in the either given register of two or more of said registers, A count count means of read-out to count the count of read-out from said stack by said read-out means, A comparison means to compare the value of said count of read-out counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said read-out means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place, It controls so that the first input of said adder serves as the contents of the stackpointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the read-out address-generation means after it ] input-control means controlled to read and to become the address. The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of said stack are read based on said read-out memory address. Based on the comparison result of said comparison means, it is characterized by controlling read-out and read-out termination of the contents of said stack including a read-out means to store in the register specified based on said count of writing.

[0057] If it does in this way, the restoration to two or more registers specified with the value which continued from shunting or the stack to the stack of two or more registers systematically specified with the continuous value is realizable only by the count means and easy sequence control. Therefore, since it is realizable in the information processing circuit of the small gate number, it is suitable for the microcomputer of a one chip etc.

[0058] This invention contains the program counter register only for program counters. The branch instruction said whose instruction groups only for stack pointers are the instruction which branches to a subroutine, and a return instruction from said subroutine is included. When said decode means decodes said branch instruction and said instruction-execution means executes said branch instruction, At least one side of the return to shunting of the contents of said program counter register to the second given area of the stack prepared in memory, and the program

counter register of the contents of said second area It is characterized by including the means performed based on the memory address specified with said stack-pointer dedicated register, and a means to update the contents of said stack-pointer dedicated register based on said shunting and said return.

[0059] In here, interruption processing, exception handling, a debugging manipulation routine, etc. are included with a subroutine. Therefore, with the instruction which branches to a subroutine, the software interrupt instruction for branching to an instruction, interruption processing, exception handling, a debugging manipulation routine, etc. which call a subroutine etc., a software debugging interruption instruction, etc. are included. Moreover, the return instruction from interruption processing, exception handling, a debugging manipulation routine, etc. is included in a return instruction from a subroutine.

[0060] Usually, when returning from the case where it branches to a subroutine, or said subroutine, shunting and a return of a program counter are needed.

[0061] In this invention, in case the instruction which carries out a return from the activation and the subroutine of an instruction which branch to said subroutine is executed, shunting and a return of said program counter are also performed to coincidence. That is, the information processing circuit of this invention has circuitry which can perform shunting and a return of a program counter with the instruction which branches to a subroutine, and any 1 instruction of the return instruction from said subroutine. For this reason, shunting of said program counter which is needed in connection with the return from branching and the subroutine to a subroutine, and an instruction of a return become unnecessary, and the number of instructions can be reduced. Moreover, improvement in the processing speed at the time of branching can be aimed at to other routines, such as a subroutine call return, without consuming a useless cycle.

[0062] Moreover, when a software interrupt instruction is generated, shunting and the return holding the current condition of information processing circuits, such as CPU, of a processor status register are also needed. Therefore, in a software interrupt instruction etc., it is desirable that it is made to perform shunting and a return of a processor status register to coincidence at the time of activation of this instruction.

[0063] This invention is an information processing circuit containing the stack pointer assigned to two or more registers which were able to be continuously set in order, and one of general-purpose registers. The object code of one [ at least ] instruction of the continuation push instruction which has two or more register specific information in object code, and a continuation pop instruction is decoded. When at least one side of a means to output a control signal based on this object code, and said continuation push instruction and said continuation pop instruction is performed, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack It is characterized by including the means performed based on the memory address specified according to the contents of said control signal and said stack-pointer dedicated register, and said two or more register specific information.

[0064] This invention relates to said continuation push instruction and said continuation pop instruction in the case of using a general-purpose register as a stack pointer.

[0065] According to this invention, if said continuation push instruction and said continuation pop instruction are executed, the same effectiveness as the case where multiple-times activation of the case where multiple-times activation of the push instruction is carried out continuously, or the pop instruction is carried out continuously will be acquired. That is, renewal of the stack

pointer accompanying an exchange and this exchange of the data between two or more registers and a stack can be performed with one instruction. For this reason, when performing the data transfer between two or more registers and a stack, it can prevent object code size increasing by repeating a push instruction or a pop instruction. Moreover, improvement in the processing speed of interruption processing and a subroutine call return can be aimed at, without avoiding that a program execution step becomes long and consuming a useless cycle.

[0066] It is characterized by the information processing circuit of \*\*\*\*\*\* being a RISC method.

[0067] The information processing circuit of a RISC method is designed for the purpose of miniaturizing hardware and attaining improvement in the speed. For this reason, it has many general-purpose registers and reduction of the number of instructions is aimed at by extracting an instruction set to the high thing of versatility.

[0068] Therefore, in the information processing circuit of a RISC method, the stack pointer was assigned to the general-purpose register, and when a stack pointer was treated, it was processing using the instruction set treating a general-purpose register. However, by such approach, an instruction length becomes large, and the utilization ratio of memory is not good.

[0069] According to this invention, in the information processing circuit of a RISC method, instruction lengths can be reduced and the utilization ratio of memory can be gathered.

[0070] The information processing circuit of this invention decodes a fixed-length instruction, and is characterized by performing executive operation based on this instruction.

[0071] If a fixed-length instruction is used, the time amount which decoding of an instruction takes can be shortened compared with the case where a variable-length instruction is used, and the circuit scale of an information processing circuit can be made small. When adopting a fixed-length instruction, in order to prevent making a redundant part to an instruction and to use memory efficiently, the number of bits required for each instruction has little dispersion, and its shorter possible one is desirable.

[0072] According to this invention, generally, an instruction length can shorten the instruction length of an instruction which deals with the stack pointer which tends to become long. Therefore, even if it is the case where a fixed-length instruction is adopted, it can prevent making a redundant part to an instruction, and memory can be used efficiently.

[0073] The microcomputer of this invention is characterized by including a means to perform I/O with the information processing circuit of this invention and storage means which were mentioned above, and the exterior.

[0074] According to this invention, processing speed can offer a quick microcomputer with the sufficient utilization ratio of memory.

[0075] The microcomputer of this invention is characterized by performing the program of the language which has the structure where relate with said stack pointer and the storage region of an auto variable is secured.

[0076] There is C as language which has the structure where relate with a stack pointer and the storage region of an auto variable is secured and to carry out. When the microcomputer of this invention processes the program of such language, processing speed and the utilization ratio of memory can be raised effectively.

[0077] The electronic equipment of this invention is characterized by including the microcomputer of this invention mentioned above.

[0078] According to this invention, since processing speed builds in the quick good information processing circuit of the utilization ratio of memory, cheap and highly efficient electronic

equipment can be offered.

[0079]

[Embodiment of the Invention] Hereafter, this example is explained based on a drawing. [0080] (Example 1)

(1) By the architecture of a load store mold, CPU of configuration this example of CPU of this example executes almost all instructions in 1 cycle with a pipeline. All instructions are described by the 16-bit fixed length, and the instruction which CPU of this example processes has realized very small object code size.

[0081] Especially CPU of this example is constituted so that the instruction set of the instruction group only for stack pointers which has a register only for stack pointers in order to describe efficiently the processing which deals with a stack pointer and to perform it, and has the object code which makes this stack-pointer dedicated register an implied operand can be decoded and performed.

[0082] <u>Drawing 1</u> is drawing for explaining the outline of the circuitry of CPU of this example. [0083] A book CPU 10 contains a register set including SP14 who are a general-purpose register 11, PC12 with which the program counter is stored, the processor status register (PSR) 13, and a register only for stack pointers, an instruction decoder 20 and the immediate generation machine 22, the address adder 30, ALU40, the PC incrementer 44 and the various internal buses 72, 74, 76, and 78, the various internal signal lines 82, 84, and 86, and 88 grades.

[0084] Said instruction decoder 20 decodes the inputted object code, performs processing required in order to execute this instruction, and outputs a required control signal. In addition, this instruction decoder 20 functions also as said decode means to decode the object code of the instruction only for said stack pointers, and to output a control signal based on this instruction. [0085] The immediate generation machine 22 generates the immediate data of 32 bits used at the time of activation based on the immediate contained in object code, or generates the constant data of 0 [ required for activation of each instruction ], \*\*1, \*\*2, and 4 [ \*\*]. The PC incrementer 44 updates the program counter stored in PC12 based on the execution cycle of an instruction. In case the address adder 30 adds the immediate data generated with the information stored in various registers, or the immediate generation vessel 22 and reads data from memory, it generates required address data. ALU40 performs math processing and logical operation. [0086] Moreover, this CPU contains various buses and a signal line inside. PA\_BUS72 and PB BUS74 have the function to transmit the input signal of ALU40 etc. WW BUS76 has the function which takes out the result of an operation of ALU40, and is transmitted to a generalpurpose register. XA BUS78 has the function to transmit the address data taken out from the general-purpose register 11 or SP14 etc. The IA signal line 82 transmits address data to external I ADDR BUS92 from each part inside CPU. The DA signal line 84 transmits address data to external D ADDR BUS96 from each part inside CPU. The DIN signal line 86 transmits data to each part inside CPU from D DATA BUS98 of the CPU exterior. The DOUT signal line 88 transmits data to external D DATA BUS98 from each part inside CPU. IA input change-over 83 switches the various signals (PA BUS72, WW BUS76, PC12, PC+2) outputted to the IA signal line 82. The DOUT input change-over 89 switches the various signals (PA\_BUS72, WW BUS76, PC12, PC+2) outputted to the DOUT signal line 88.

[0087] Moreover, said each part of CPU10 functions based on the control signal which said instruction decoder 20 outputs also as said activation means to execute an instruction and to perform the instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[0088] A book CPU 10 performs an exchange of the exterior and a signal through the instruction address bus (I\_ADDR\_BUS) 92 for the 16-bit instruction data bus (I\_DATA\_BUS) 94 and an instruction data access, the 32-bit data bus (D\_DATA\_BUS) 98, the data address bus (D\_ADDR\_BUS) 96 for a data access, and the control bus that is not illustrated for a control signal.

[0089] (2) the explanation of a register set in which this example carries out CPU \*\* -- explain a part required about the outline of the register set which CPU of this example has next. [0090] The register set which CPU of this example has in <u>drawing 2</u> is shown. CPU of this example has the register set which contains 16, and PC12, PSR13, SP14, ALR (arithmetic operation low register)15 that is not illustrated and AHR (arithmetic operation high register)16 which is not illustrated for a general-purpose register 11.

[0091] said general-purpose register 11 -- functional -- a 32-bit equivalent register -- it is -- R0 to R15, and naming \*\*\*\*\*. This general-purpose register 11 is used at the time of a data operation and address computation.

[0092] Moreover, PC12 is the incremental counter of 32 bit length, and holds the program counter which is the address of the instruction under current activation. In the text, when pointing out a register name, it is called PC, and it is called a program counter when putting the value stored in PC.

[0093] Direct access of this PC12 cannot be carried out by a load instruction etc. If a call instruction, an int instruction, interruption, and an exception occur, a program counter will be read from PC12 and will be evacuated to a stack. Thus, it will fly, if branch instruction is executed, and the point address is set as PC. It is also the same as when branching with a conditional-branching instruction. And the return point instruction address is read by a ret instruction and reti instruction from a stack, and returns to PC12 with them.

[0094] PSR (processor status register)13 is a 32-bit register to which the flag is assigned, and holds the current condition of CPU. If an int instruction, interruption, an exception, etc. occur, in case it will branch to each manipulation routine, the condition of PSR at that time is evacuated to a stack. Conversely, by activation of a reti instruction, the evacuated value returns to PSR. [0095] SP14 is a register only for [ of 32 bits ] stack pointers, and the stack pointer which puts the head address of a stack is stored. In the text, when pointing out a register name, it is called SP, and it is called a stack pointer when putting the value stored in SP. However, since the stack pointer has always pointed out the boundary of WORD, 2 bits of the low order of said stack pointer are always 0.

[0096] This stack pointer is updated with activation of the various instructions included in the instruction group only for stack pointers currently prepared by this example, and generating of a trap. There are an instruction which branches to other routines, such as a call instruction and a ret instruction, as an instruction only for stack pointers which updates a stack pointer, a stack-pointer migration instruction, a pushn instruction, a popn instruction, etc. For example, if a call instruction is executed, the decrement (-4) of the stack pointer will be first carried out only for wordsize (4), and PC12 will be evacuated to a stack. Moreover, if a ret instruction is executed, the return point address will be conversely loaded to PC from a stack, and the wordsize part increment (+4) of the stack pointer will be carried out. When an int instruction is executed, or it interrupts and an exception etc. occurs, the value of PC or PSR is evacuated to a stack in the following procedures.

[0097] 1) Evacuate PC to the head address of the stack to which it is pointed out with SP=SP-42 stack pointer.

[0098] 3) Evacuate PSR to the head address of the stack to which it is pointed out with SP=SP-44 stack pointer.

[0099] If a reti instruction is executed, processing contrary to the above will be performed and CPU will return to a former condition. Thus, activation of a call instruction, a ret instruction, and an int instruction updates a stack pointer based on this activation. About the detail of each instruction, it mentions later.

[0100] Moreover, in this example, a trap means what doubled the exception generated by activation of interruption and the instruction which are generated in activation of an instruction asynchronous. If a trap occurs, CPU will read a vector table from a trap table, after evacuating a program counter (PC) and a processor status register (PSR) to a stack, and will branch to the manipulation routine corresponding to the trap. With generating of a trap, IE bit in PSR (enable [interruption]) is cleared, and generating of mask possible interruption beyond it is forbidden. In order to enable again external interruption in which a mask is possible, 1 is written in and set as IE bit of PSR using the load instruction to PSR.

[0101] A reti instruction is used in order to return to the original routine from trap processing. If a reti instruction is executed, CPU will branch to the return address while it is read from a stack in order of PSR and PC and returns PSR to the original value. In addition, there are a debugging exception, an address irregular train exception, an overflow exception, a division-by-zero exception, etc. as exception.

[0102] Explanation is omitted about ALR (arithmetic operation low register)15 and AHR (arithmetic operation high register)16.

[0103] The special registers PSR13, SP14, ALR15, and AHR16 which CPU has can perform data transfer between general-purpose registers using a load instruction. Each register has a special register number and is accessed using this number.
[0104]

A special register name Special register number The description approach processor status register of an assembler 0 % PSRSP 1 % SP arithmetic operation low register 2 % An ALR arithmetic operation high register From the lower part of the field which followed memory in the already kicked temporary storage, data accumulate a 3 %AHR (3) stack and the explanation stack about a stack pointer on ledged, and they are memorized. The stack pointer shows the address of the data memorized, the top, i.e., last, of a stack memory.

[0105] General actuation of a stack pointer is explained using drawing 3.

[0106] 100 of drawing 3 expresses the stack area established in memory. Supposing a shadow area 102 is data stored at the end, the stack pointer stored in SP14 shows the memory address 1000 of these data. In addition, the lower part field 104 of a shadow area 102 is a field where data are already stored, and the upper part field 106 of a shadow area 102 shows the field where data will be stored from now on.

[0107] Since the stack pointer has always pointed out the boundary of WORD, when writing information in a stack, it stores information in the location where only 4 moves upwards the stack pointer with which SP14 was stored, and this stack pointer points to it. Moreover, when taking out the information stored in the stack, the information on the address which current [SP/14] shows is taken out, and only 4 moves downward the stack pointer stored in SP14. Thus, the stack pointer shows the storing address of the information always stored in the stack finally. [0108] (4) Although a general-purpose register is used as a stack pointer in CPU of the explanation usual RISC method about the instruction group only for stack pointers, in this example, it has SP14 who is a register only for stack pointers, and is set as the actuation object of

said instruction group only for stack pointers.

[0109] Said instruction group only for stack pointers is the generic name of two or more instructions which make an implied operand SP14 who is a register only for stack pointers, and operate it by being with SP14. This instruction group only for stack pointers includes the instruction which branches to other routines, such as SP relative load instructions (ld etc.), a stack-pointer migration instruction (add, sub), instructions (call etc.) that branch to a subroutine, and return instructions (ret etc.), a continuation push instruction (pushn), and a continuation pop instruction (popn).

[0110] Since it is the instruction only for stack pointers, I hear that it is common in the instruction of \*\*\*\*\*\*\* has the unnecessary information for specifying a stack pointer to object code, and it is in it. Therefore, the effectiveness that a short instruction length can describe the processing using a stack pointer efficiently is also common.

[0111] Moreover, if these instructions are used, information memorized by the stack prepared in memory can be processed efficiently. Moreover, interruption processing and processing of a subroutine call return can be performed efficiently.

[0112] Here, the busy condition of the already kicked stack and the condition of a stack pointer are explained to the example of use and memory of the instruction only for said stack pointers in case a subroutine is called using drawing 4. The main program 500 and subroutine 520 of drawing 4 are the program described by the object code which the C compiler created. 540 shows the condition of the stack on memory. 502 shows that processing which uses general-purpose registers R0-R3 is performed. 506 shows the subroutine call instruction. The back stack pointer (SP) with which the instruction before the subroutine call instruction with which a subroutine call instruction is executed by the main program 500 (i.e., before being shown in 504) was executed presupposes that the address of \*\* on the stack 540 on memory was pointed out. If said subroutine call instruction is executed, control of activation will be crossed to a subroutine 520. At this time, the instruction (call instruction) which branches to the subroutine which is the instruction only for said stack pointers is executed by this example. As for the value of a stack pointer (SP), activation of this instruction stores the return address to a main program in the area 544 on the stack to which the increment only of -4 was carried out (refer to \*\*SP of drawing 4), and this stack-pointer \*\*SP has pointed it out automatically.

[0113] And in a subroutine 520 side, processing which transmits to a stack the value stored in the general-purpose registers R0-R3 currently used for the beginning of activation by the main program is performed. 524 shows the continuation push instruction (pushn) which is an instruction only for stack pointers which performs processing which shunts to a stack the value stored in general-purpose registers R0-R3. If this instruction is executed, the value stored in general-purpose registers R0-R3 will be continuously transmitted to a stack, and it is stored in a stack 540 as shown in 550 of drawing 4. The stack pointer (SP) has pointed out 546 as activation of this processing finishes (524\*\*) (\*\*SP).

[0114] Next, in a subroutine 520, the auto variable area used by the subroutine is secured. The add instruction shown in 526 is a stack-pointer migration instruction which is an instruction only for stack pointers, and secures the stack area which is made to move a stack pointer up and is used by the subroutine 520. If this instruction is executed, only X cutting tool will move a stack pointer (SP) to the upper location 548 (\*\*SP), and the field of the auto variable which the subroutine shown in notes 2 uses will be secured.

[0115] It is shown that 528 performs processing which used an auto variable and general-purpose registers R0-R3 by the subroutine 520. At this time, the location of a stack pointer has pointed

out \*\*SP, and loading of an auto variable is performed by being with the load instruction only for SPs which is an instruction only for stack pointers.

[0116] 529 shows said SP load instruction which transmits the auto variable S1 stored on memory to a general-purpose register R1. Said auto variable S1 is stored in the location which has Y bytes of offset value from a stack pointer (\*\*SP). Since a stack pointer does not move in the midst of processing of 528 of a subroutine as mentioned above, the memory address of an auto variable is specified with a stack-pointer + offset value, and can perform the exchange with a general-purpose register efficiently using the load instruction only for said SPs.

[0117] Moreover, before returning from a subroutine 520 to a main program 500, the value of the general-purpose registers R0-R3 which had shunted to the stack is returned to general-purpose registers R0-R3, and it must be made for a stack pointer to have to point out the area 544 where the return address to a main routine is stored. Therefore, the stack pointer to which it was made to move with the stack-pointer migration instruction of 526 is first returned to the location of a basis. The sub instruction shown in 530 is a stack-pointer migration instruction which is an instruction only for stack pointers, and moves a stack pointer caudad. Activation of this instruction moves a stack pointer to 546 (refer to \*\*SP). Next, processing which restores the information 550 stored in the stack to general-purpose registers R0-R3 is performed. 532 shows the continuation pop instruction (popn) which is an instruction only for stack pointers which performs processing which transmits the information on a stack to general-purpose registers R0-R3. If this instruction is executed, the value 550 stored in the stack will be continuously transmitted to general-purpose registers R0-R3, and it is stored in a stack 540 as shown in 550 of drawing 4 activation of this processing -- finishing (532\*\*) -- the stack pointer has pointed out 544 (refer to \*\*SP).

[0118] 534 shows the return instruction. If said return instruction is executed, control of activation will be crossed to a main program 500. At this time, the return instruction (ret instruction) which is an instruction only for said stack pointers is executed by this example. If this instruction is executed, it will branch to the instruction which the return address to the main program stored in the stack area which \*\*SP points out shows, namely, will return to the instruction 507 next to a main program 500. And the value of a stack pointer moves to the head area of a stack where the increment only of +4 is carried out, and a main program 500 uses it automatically (refer to \*\*SP of drawing 4).

[0119] The circuitry for executing explanation and this instruction of an instruction about each [ said ] instruction only for stack pointers below, respectively, the motion at the time of activation, etc. are explained to a detail.

[0120] (5) Create the object code a C compiler relates the field of an auto variable with a stack pointer, and it is remembered that carried out the stack-pointer relative load instruction above-mentioned. Specifically, the C compiler is the specification which secures Y bytes of field of an auto variable from a stack pointer in the place whose offset is X.

[0121] <u>Drawing 5</u> is drawing for explaining the processing which transmits the auto variable on memory to a register. The auto variable a is [ halfword data and auto variable d-g of WORD data and the auto variables b and c ] cutting tool data. The stack pointer stored in SP shows 1000 which is the address of the head field of the field 600 where the auto variable on a stack is stored. The area on the stack which makes said stack pointer a memory address as area for storing the auto variable a The area on the stack which makes a memory address a stack pointer +2 and a stack pointer +4 as area for storing the auto variables b and c, respectively The area on the stack which makes a memory address a stack pointer +5, a stack pointer +6, a stack pointer +7, and a

stack pointer +8 as area for storing auto variable d-g, respectively is secured. And in case given processing is performed, data transfer processing is needed between the auto variable specified by the memory address of a stack-pointer + offset value, and a general-purpose register. [0122] In CPU of this example, in order for short object code to describe such transfer processing and to perform it efficiently, the instruction set shown below is prepared as an SP relative load instruction which is one of the instructions only for stack pointers. [0123]

ld.b %Rd [%sp+imm6] -- (1)

ld.ub %Rd [%sp+imm6] -- (2)

ld.h %Rd [%sp+imm7] -- (3)

ld.uh %Rd [%sp+imm7] -- (4)

ld.w %Rd [%sp+imm8] -- (5)

ld.b [%sp+imm6] %Rs -- (6)

ld.h [%sp+imm7] %Rs -- (7)

ld.w [%sp+imm8] %Rs -- (8)

(1) - (8) describes instruction code by the assembler. (1) is an instruction which carries out the sign escape of the cutting tool data from a stack, and is transmitted to a register. (2) is an instruction which carries out the zero escape of the cutting tool data from a stack, and is transmitted to a register. (3) is an instruction which carries out the sign escape of the halfword data from a stack, and is transmitted to a register. (4) is an instruction which carries out the zero escape of the halfword data from a stack, and is transmitted to a register. (5) is an instruction which transmits WORD data to a register from a stack. (6) is an instruction which transmits cutting tool data to a stack from a register, (7) is an instruction which transmits halfword data to a stack from a register, and (8) is an instruction which transmits WORD data to a stack from a register.

[0124] [%sp+imm6], [%sp+imm7], and [%sp+imm8] express immediate offset information, respectively, the offset value generated based on this immediate offset information at the time of activation and the value of the stack pointer stored in SP14 are added, and a memory address is generated. When the data size of the data on memory is a cutting tool, [%sp+imm7 of [%sp+imm6]] is immediate offset information when the data size of the data on memory is a halfword, in case the data size of the data on memory of [%sp+imm8] is WORD. Each of these is described as 6-bit immediate offset information 614 on object code by the business shown in drawing 6 (A) mentioned later. However, in imm7, at the time of an instruction execution, the offset value which should carry out the 1-bit left logic shift of the immediate offset information 614, and should be added to a stack pointer is generated (namely, when data size is a halfword). Moreover, in imm8, the offset value which should carry out the 2-bit left logic shift of the immediate offset information 614, and should be added to a stack pointer is generated (namely, when data size is WORD).

[0125] In here, a stack can mean the temporary storage established in memory, and the location of the auto variable (a-g) on the stack which is said memory address, for example, is shown in drawing 5 can be specified.

[0126] <u>Drawing 6</u> (A) is the bit field 610 of SP relative load instruction of aforementioned (1) - (8). As shown in <u>drawing 6</u> (A), SP relative load instruction has 16-bit object code including the register number 616 (4 bits) of the general-purpose register with which an actuation function serves as the operation code 612 (6 bits) which shows that it is a data transfer between memory and a register, the immediate offset information (6 bits) 614 specified by the immediate, and a

candidate for a transfer. Said operation code 612 contains a different code given according to the exception of the common code which shows that it is the load instruction which makes SP14 applicable to actuation, said data size, a sign escape, and a zero escape. Therefore, since it turns out that the stack pointer stored in SP14 by the operation code is made applicable to actuation, information about a stack pointer is not needed for the operand of object code. The immediate offset information 614 is the information for generating the offset value from the stack pointer of the data used as the candidate for a transfer. This is specified by 6 bits regardless of [ having mentioned above ] data size. The register number of the register with which the data with which the register number of the register with which the data with which it began to be read from a stack in aforementioned (1) - (5) are stored is written in a stack in aforementioned (6) - (8) are stored is contained in the address 616 of the register used as the candidate for a transfer. [0127] Drawing 6 (B) shows the example of the bit field 620 of the object code of the load instruction (henceforth a general-purpose load instruction) which makes applicable to actuation the general-purpose register used when a general-purpose register is used as a stack pointer. [0128] As shown in drawing 6 (B), the general-purpose load instruction has 20-bit object code including the operation code 622 (6 bits) an actuation function indicates it to be that it is a data transfer between memory and a general-purpose register, the immediate offset information 624 (6 bits) that it was specified by the immediate and the first register number 626 (4 bits) which specifies the general-purpose register used as a stack pointer, and the second register number 628 (4 bits) which specifies the general-purpose register with which it becomes a candidate for a transfer. In a general-purpose microcomputer, since instruction lengths are 8 bitwises, they become 24 bits or a 32-bit instruction.

[0129] Although each of <u>drawing 6</u> (A) and (B) shows the object code of the instruction used when performing data transfer processing between the memory addresses and registers which are specified as a stack pointer by adding an offset value, as shown in this drawing, it can describe SP relative load instruction by short object code compared with a general-purpose load instruction.

[0130] Hereafter, (5) orders as an instruction which transmits data to a register from a stack (since it is the instruction which reads WORD data from a stack to a register). (8) orders below as an instruction which is called SP relative load instruction of WORD data read-out and which transmits data to a stack from a register (since it is the instruction which incorporates WORD data from a register to a stack). SP relative load instruction of following WORD data writing -- saying -- the configuration for taking for an example and executing these instructions and the actuation at the time of activation are explained.

[0131] A hardware configuration required in order to execute these instructions using drawing 1 first is explained. These instructions are transmitted through I\_DATA\_BUS94 from the external memory (ROM) 52, and are inputted into the instruction decoder 20 of CPU10. By this instruction decoder 20, an instruction is decoded and the various signals required for activation of an instruction which are not illustrated are outputted. Moreover, said immediate generation machine 22 performs the left logic shift of said immediate offset information 614 according to data size, generates the offset value used for a sign escape and zero escape deed activation if needed, and outputs it to PB\_BUS74. SP14 stores the stack pointer and can output this value to XA\_BUS78 connected to the input of the address adder 30. Another input of the address adder 30 is connected to PB\_BUS74 which is the output of the immediate generation machine 22. The output (ADDR) of the address adder 30 is connected to external D\_ADDR\_BUS96 through the DA signal line 84.

[0132] A bus control unit (BCU) 60 controls I/O of data with the memory (RAM, ROM) 50 and 52 including stack area based on the various request signals (signal outputted to the external bus) outputted from CPU, and outputs READ and a WRITE control signal.

[0133] The actuation at the time of activation of SP relative load instruction of WORD data readout is explained first.

[0134] If SP relative load instruction of WORD data read-out is executed, the value of the stack pointer stored in SP14 and the offset value which the immediate generation machine 22 generated based on said immediate offset information 614 will be added, and the memory address for memory read-out will be generated. And the information on memory is read based on this memory address, and it is transmitted to the general-purpose register specified by said register number 616 of object code.

[0135] <u>Drawing 7</u> is a flow chart Fig. for explaining actuation of SP relative load instruction of WORD data read-out.

[0136] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 210). Moreover, the offset value imm which the immediate generation machine 22 generated from immediate offset information is outputted to PB\_BUS74 (step 212). The address adder 30 adds the value on said XA\_BUS78, and the value on said PB\_BUS74, and outputs the read-out address of the memory which is a result (ADDR) to D\_ADDR\_BUS96 through the DA signal line 84 (step 214, step 216). And the data read-out request signal from CPU to BCU60 becomes active, and the read cycle of external memory is performed (step 218). That is, based on this request signal, data are read from memory by making said read-out address into a memory address, and said BCU60 is controlled to be outputted to D\_DATA\_BUS98. The data on D\_DATA\_BUS98 are outputted to WW\_BUS76 through the DIN signal line 86 (step 220). And the value on WW\_BUS76 is stored in the register (%Rd) which has the register number specified in the address (4 bits) 616 of the register (Rs/Rd) set as the transfer object of instruction code (step 222).

[0137] Next, the actuation at the time of activation of SP relative load instruction of WORD data writing is explained.

[0138] If SP relative load instruction of WORD data writing is executed, the value of the stack pointer stored in SP14 and the offset value which the immediate generation machine 22 generated based on said immediate offset information 614 will be added, and the memory address for memory writing will be generated. And the information stored in the general-purpose register specified by said register number 616 of object code is transmitted to the area on the memory specified based on this memory address.

[0139] <u>Drawing 8</u> is a flow chart Fig. for explaining actuation of SP relative load instruction of WORD data writing.

[0140] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 230). Moreover, the offset value imm which the immediate generation machine 22 generated from immediate offset information is outputted to PB\_BUS74 (step 232). The address adder 30 adds the value on said XA\_BUS78, and the value on said PB\_BUS74, and outputs the write-in address to the memory which is a result (ADDR) to D\_ADDR\_BUS96 through the DA signal line 84 (step 234, step 236). Moreover, the data stored in the register (%Rd) which has the register number specified in the address (4 bits) 616 of the register (Rs/Rd) set as the transfer object of instruction code are outputted to PA\_BUS72 (step 238). The data on PA\_BUS72 are outputted to D\_DATA\_BUS98 through the DOUT signal line 88 (step 240). And the data write-in request signal from CPU to BCU60 becomes active, and the

light cycle of external memory is performed (step 242). Namely, said BCU60 controls the actuation which writes the data transmitted by D\_DATA\_BUS98 in memory 50 by making said write-in address into a memory address based on said request signal.

[0141] (6) Stack-pointer migration instruction <u>drawing 9</u> (A) - (F) is drawing for explaining the busy condition of the stack on the memory by each routine in case a program is performed over two or more routines, and the condition of a stack pointer.

[0142] The condition of the stack area on the memory at the time of activation of the given processing a of the MAIN routine 210 shown in <u>drawing 9</u> (A) and the condition of a stack pointer (value stored in SP14) are shown in <u>drawing 9</u> (D). 222 shows the stack area for using it by the MAIN routine 210, and the stack pointer shows the start address 232 of 222.

[0143] SUB1 routine 212 of <u>drawing 9</u> (B) is a subroutine called and performed from said MAIN routine 210. The condition of the stack area on the memory at the time of activation of the given processing b213 of this SUB1 routine 212 and the condition of a stack pointer (value stored in SP) are shown in <u>drawing 9</u> (E). 224 shows the stack area for using it by SUB1 routine 212, and the stack pointer shows the start address 234 of 224.

[0144] SUB2 routine 214 of <u>drawing 9</u> (C) is a subroutine called and performed from said SUB1 routine 210. The condition of the stack area on the memory at the time of activation of the given processing c215 of this SUB2 routine 214 and the condition of a stack pointer (value stored in SP) are shown in <u>drawing 9</u> (F). 226 shows the stack area for using it by SUB2 routine 214, and the stack pointer shows the start address 236 of 226.

[0145] Thus, when activation is performed over two or more subroutines, in order that the stack area used by each routine may move, moving to the head of a stack area which uses the value of a stack pointer by each routine in connection with it is performed.

[0146] In CPU of this example, in order for short object code to describe migration processing of such a stack pointer and to perform it efficiently, the instruction set shown below is prepared as a stack-pointer migration instruction which is one of the instructions only for stack pointers.

[0147]

add % -- sp and imm12 -- (9)

sub % -- sp and imm12 -- (10)

(9) and (10) describe instruction code by the assembler. (9) is the ADI instruction to the stack pointer stored in SP14, and (10) is the SUI instruction to the stack pointer stored in SP14. After imm12 shifts the immediate of 10 bits contained in the object code of an instruction leftward [2 bit], a zero escape is carried out, and it serves as 32 bit data, and is used for an operation with the stack pointer stored in SP14.

[0148] Drawing 10 (A) is the bit field 630 of a stack-pointer migration instruction of the above (9) and (10). As shown in drawing 10 (A), the stack-pointer migration instruction has 16-bit object code including the operation code 632 (6 bits) which shows that it is addition and subtraction of the migration information on the stack pointer with which the actuation function was stored in SP14, and the immediate migration information 634 (10 bits) specified by the immediate. Said operation code 632 contains a different code given according to the exception of the common code which shows that it is the stack-pointer migration instruction which makes SP14 applicable to actuation, addition, and subtraction. Therefore, since it turns out that the stack pointer stored in SP14 by the operation code is made applicable to actuation, information about a stack pointer is not needed for the operand of object code. The immediate migration information 634 is the information for generating the offset value which performs addition or subtraction to a stack pointer.

- [0149] <u>Drawing 10</u> (B) shows the example of the bit field 640 of the object code of the addition used when a general-purpose register is used as a stack pointer, and a subtraction instruction (henceforth general-purpose operation instruction).
- [0150] As shown in drawing 10 (B), general-purpose operation instruction has 20-bit object code including the register number 646 (4 bits) which specifies the general-purpose register with which an actuation function serves as the operation code 642 (6 bits) which shows that it is addition and subtraction of the immediate operation information on the value of a general-purpose register, the immediate operation information 644 (10 bits) specified by the immediate, and a candidate for actuation. In a general-purpose microcomputer, since instruction lengths are 8 bitwises, they become 24 bits or a 32-bit instruction.
- [0151] Although each of <u>drawing 10</u> (A) and (B) is the object codes of the instruction used when performing processing which adds and subtracts an immediate to a stack pointer, as shown in this drawing, it can describe a stack-pointer migration instruction by short object code compared with general-purpose operation instruction.
- [0152] Hereafter, the configuration for executing the ADI instruction (henceforth an addition stack-pointer migration instruction) to SP of (9) and the SUI instruction (henceforth a subtraction stack-pointer migration instruction) to SP of (10) and the actuation at the time of activation are explained.
- [0153] A hardware configuration required in order to execute these instructions using drawing 1 first is explained. These instructions are transmitted through I\_DATA\_BUS94 from the external memory (ROM) 52, and are inputted into the instruction decoder 20 of CPU10. By this instruction decoder 20, an instruction is decoded and the various signals required for activation of an instruction which are not illustrated are outputted. Moreover, said immediate generation machine 22 carries out the 2-bit left logic shift of the 10 bits of said immediate migration information 634, carries out a zero escape and outputs them to PA\_BUS72. SP14 stores the stack pointer and this value is outputted to XA\_BUS78. XA\_BUS78 is connected to PB\_BUS74 used as the input of ALU40. Another input of ALU40 is connected to PA\_BUS72 which is the output of the immediate generation machine 22. The output of ALU40 is connected to WW\_BUS76. WW BUS76 is connected to SP's input.
- [0154] The actuation at the time of activation of an addition stack-pointer migration instruction is explained first.
- [0155] When an addition stack-pointer migration instruction is executed, the value of the stack pointer stored in SP14 and the migration immediate which the immediate generation machine 22 generated based on said immediate migration information 634 are added, a new stack pointer is generated, and the value is stored in SP14.
- [0156] <u>Drawing 11</u> is a flow chart Fig. for explaining actuation of an addition stack-pointer migration instruction.
- [0157] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 250). And the data on said XA\_BUS78 are outputted to PB\_BUS74 (step 252). Moreover, the migration immediate imm which the immediate generation machine 22 generated based on immediate migration information is outputted to PA\_BUS72 (step 254). ALU40 adds the value on said PB\_BUS74, and the value on said PA\_BUS72, and outputs a result to WW\_BUS76 (step 256). And the value on WW\_BUS76 is inputted into SP14 (step 258).
- [0158] Next, the actuation at the time of activation of a subtraction stack-pointer migration instruction is explained.

[0159] When a subtraction stack-pointer migration instruction is executed, the migration immediate which the immediate generation machine 22 generated based on said immediate migration information 634 is subtracted from the value of the stack pointer stored in SP14, a new stack pointer is generated, and the value is stored in SP14.

[0160] <u>Drawing 12</u> is a flow chart Fig. for explaining actuation of a subtraction stack-pointer migration instruction.

[0161] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 260). And the data on said XA\_BUS78 are outputted to PB\_BUS74 (step 262). Moreover, the migration immediate imm which the immediate generation machine 22 generated based on immediate migration information is outputted to PA\_BUS72 (step 264). ALU40 subtracts the value on said PA\_BUS72 from the value on said PB\_BUS74, and outputs a result to WW\_BUS76 (step 266). And the value on WW\_BUS76 is inputted into SP14 (step 268).

[0162] (7) Branch instruction drawing 13 is drawing for explaining control of the program execution by a call instruction and ret instruction. If the call instruction for branching to a subroutine SUB 310 is executed in the MAIN routine 300 as shown in drawing 13 (302), control will include a subroutine SUB 310. The ret instruction (312) is written to the last of a subroutine, and if this instruction is executed, it will return to the next instruction (304) of said call instruction (302) of the MAIN routine 300. Therefore, when shown in drawing 13, a program will be performed in order of \*\*\*\*\*\*. Thus, after activation by the subroutine SUB 310 finishes, in order to perform from the next instruction (304) of return and said call instruction (302) to the MAIN routine 300, in case it branches to a subroutine SUB 310, it is necessary [it] for somewhere to memorize the address of the return point. For this reason, in the case of the branch instruction activation which branches to subroutines, such as a call instruction, as drawing 4 explained, processing which shunts the return point address to a stack is performed, and in the case of activation of the branch instruction which returns from subroutines, such as a ret instruction, processing (henceforth shunting of a program counter and restorative processing) which returns the return point address to a program counter from said stack is performed. [0163] Since shunting of said program counter and restorative processing were realized by software, in case decision instructions, such as a call instruction, were executed, in order to perform these processings, object code (assembler instruction) was also required of CPU of the conventional RISC method. For example, in case a call instruction was executed, the object code (assembler instruction) for only wordsize (4) carrying out the decrement (-4) of the stack pointer, and storing the address of the next instruction of a call instruction in a stack based on the value of a program counter was required.

[0164] However, CPU of this example has a hardware configuration which also performs shunting of said program counter, and restorative processing together, if said call instruction and ret instruction are executed. Therefore, the object code (assembler instruction) which describes shunting of said program counter and restorative processing is not needed apart from said call instruction or ret instruction. In CPU of this example, in order to perform shunting of such said program counter, and restorative processing with one instruction, the instruction set shown below as branch instruction which is one of the instructions only for stack pointers is prepared.

```
[0165] call sign9 -- (11)
call %Rb -- (12)
ret -- (13)
reti -- (14)
```

```
retd -- (15)
int imm2 -- (16)
brk -- (17)
```

(11) - (17) describes instruction code by the assembler. (11) is PC relative subroutine call instruction, and is a call instruction which specifies the branching place address relatively and branches based on the displacement information sign9 specified with the operand by making a program counter PC into a base address. (12) is a register indirect subroutine call instruction, and is a call instruction which branches to the branching place address stored in the register specified with the operand. (13) is a return instruction from a subroutine. (14) is a return instruction from interruption or an exception-handling routine. (15) is a return instruction from a debugging manipulation routine. (16) is a software interrupt instruction. (17) is a software debugging interruption instruction.

[0166] Drawing 14 is the bit field 650 of PC relative subroutine call instruction of the above (11). It has 16-bit object code including displacement information sign9 (8 bits) 654 as which PC relative subroutine call instruction was specified by the operation code 652 (8 bits) an actuation function indicates it to be that it is the call instruction which specifies the branching place address relatively by making a program counter into a base address, and branches to a subroutine, and the immediate as shown in drawing 14. After a logic shift is carried out to the 1-bit left at the time of activation, the sign escape of said immediate of 8 bits is carried out. [0167] By CPU of this example, shunting to the stack of a program counter can also be performed to a call instruction execution only by the object code shown in drawing 14. [0168] The configuration for executing these instructions hereafter taking the case of the return instruction of (13) as PC relative subroutine call instruction of (11) and an instruction which carries out a return from a subroutine as an instruction which branches to a subroutine, and the actuation at the time of activation are explained.

[0169] A hardware configuration required in order to execute these instructions using drawing 1 first is explained. These instructions are transmitted through I\_DATA\_BUS94 from the external memory (ROM) 52, and are inputted into the instruction decoder 20 of CPU10. By this instruction decoder 20, an instruction is decoded and the various signals required for activation of an instruction which are not illustrated are outputted. Moreover, after said immediate generation machine 22 carries out the logic shift of said displacement information 654 to the 1-bit left, it carries out a sign escape, generates the 32-bit immediate displacement imm, and it outputs it to PB\_BUS74. SP14 stores the stack pointer and can output this value to XA\_BUS78 connected to the input of the address adder 30. Another input of the address adder 30 is connected to PB\_BUS74 which is the output of the immediate generation machine 22. The output (ADDR) of the address adder 30 is connected to external I\_ADDR\_BUS92 through the IA signal line 82.

[0170] Moreover, I\_ADDR\_BUS92 and I\_DATA\_BUS94 are connected to ROM52 in which the object code of an instruction was stored, and a bus control unit (BCU) 60 outputs the READ control signal which reads the object code of said instruction from memory (ROM) 52 based on the various request signals (signal outputted to the external bus) outputted from CPU. [0171] The actuation at the time of activation of PC relative subroutine call instruction is explained first.

[0172] If PC relative subroutine call instruction is executed, as <u>drawing 4</u> explained, the value of the program counter stored in PC12 will shunt to a stack, and the decrement of the value of the stack pointer stored in SP14 will be carried out only for wordsize (4). And the branching place

address which added a program counter and said 32-bit immediate displacement to PC12, and was obtained is set.

[0173] <u>Drawing 15</u> is a flow chart Fig. for explaining actuation of PC relative subroutine call instruction.

[0174] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 270). This serves as one input of an address adder, and the constant data (-4) which the immediate generation machine 22 generated serve as an input of another side of the address adder 30. and the stack which adds the value of the stack pointer on said XA\_BUS78, and -4 with the address adder 30, and stores the return address -- a write-in address generation is carried out and it is outputted to WW\_BUS76. Moreover, said write-in address is outputted to D\_ADDR\_BUS96 through the DA signal line 84. (Step 272). Moreover, in the PC incrementer 44, the value of the program counter stored in PC12 is carried out +two, the return address is generated, and it is outputted to D\_DATA\_BUS98 through the DOUT signal line 88 (step 274). And the data beginning request signal from CPU to BCU60 becomes active, and the light cycle of external memory is performed (step 276). That is, said return address is stored in the stack which said BCU60 made said write-in address the memory address based on this request signal, and was prepared in memory.

[0175] And the value on WW\_BUS76 is outputted to SP14 (step 278). That is, the value of a stack pointer is updated by the value carried out -four.

[0176] Next, the program counter stored in PC12 is outputted to XA\_BUS78 (step 280). Moreover, after said immediate generation machine 22 carries out the logic shift of said displacement information 654 included in the object code of an instruction to the 1-bit left, it carries out a sign escape, generates the 32-bit immediate displacement imm, and it outputs it to PB\_BUS74. Said address adder 30 adds the immediate displacement imm on the program counter on XA\_BUS78, and PB\_BUS74, generates a branch address (ADDR), and outputs it to I\_ADDR\_BUS92 through the IA signal line 82 (step 282). And the instruction read-out request signal from CPU to BCU60 becomes active, the read cycle of external memory (ROM) 52 is performed, and the object code of an instruction of a branching place is read (step 284).

[0177] Next, the actuation at the time of activation of a ret instruction is explained.

[0178] If a ret instruction is executed, as <u>drawing 4</u> explained, the value of the program counter which had shunted to the stack will return to PC12, and the increment of the value of the stack pointer stored in SP14 will be carried out only for wordsize (4).

[0179] Drawing 16 is a flow chart Fig. for explaining actuation of a ret instruction.

[0180] Before activation of said instruction, the address of a stack with which the return point address to the called routine was stored is in the stack pointer stored in SP14 very.

[0181] The stack pointer stored in SP14 at the beginning of activation of said instruction is outputted to XA\_BUS78 (step 290). And the stack pointer on XA\_BUS78 is outputted to D\_ADDR\_BUS96 (step 292). And the data reading request signal from CPU to BCU60 becomes active, and the read cycle of external memory is performed. That is, said BCU60 reads said return address from the stack prepared in memory by making said stack pointer into a memory address based on this request signal. Said return point address read from memory (RAM) 50 is crowded for the interior of CPU through the DIN signal line 86 from D\_DATA\_BUS94, and is further outputted to I\_ADDR\_BUS92 through the IA signal line 82 from a DIN signal line (step 294). And the instruction read-out request signal from CPU to BCU60 becomes active, the read cycle of external memory (ROM) 52 is performed, and the object code of an instruction of the return point address is read (step 296).

- [0182] And the value of the stack pointer on XA\_BUS78 serves as one input of said address adder 30. Moreover, the constant data (+4) which the immediate generation machine 22 generated serve as an input of another side of the address adder 30. And the value of the stack pointer on said XA\_BUS78 and +4 are added with the address adder 30, the address of the head area of the stack area which the routine of the return point secured is generated, and it is outputted to WW\_BUS76 (step 298). And said address on WW\_BUS76 (address of the head area of the stack area which the routine of the return point secured) is outputted to SP14 (step 300).
- [0183] (8) Without especially CPU of a RISC method having many general-purpose registers in the interior in order [ latest ] to raise the engine performance, and accessing memory, as the continuation push instruction (pushn) and the continuation pop instruction (popn) carried out the explanation above-mentioned, it is constituted so that many may be processed at a high speed inside CPU. This example also has 16 general-purpose registers in the interior, and is attaining improvement in the speed of processing. However, if it has many internal registers in this way, the number of registers which should be evacuated will increase in the case of interruption processing or processing of the register evacuation at the time of a subroutine call, and restoration.
- [0184] When shunting and restoration of such a register were performed, the push instruction which stores in a stack the contents specified by the address part, and the pop instruction which takes out the contents of the stack to a register were used conventionally. The motion at the time of a common push instruction and a pop instruction is explained here.
- [0185] <u>Drawing 17</u> (A) and (B) are drawings having shown typically the motion at the time of a push instruction execution, and <u>drawing 18</u> (A) and (B) are drawings having shown typically the motion at the time of a pop instruction execution. The motion in the case of performing a data transfer between two or more general-purpose registers and a stack is explained using <u>drawing</u> 17 (A), (B), and <u>drawing 18</u> (A) and (B).
- [0186] <u>Drawing 17</u> (A) shows the motion when 'push R1' which is the instruction which writes out the contents of the general-purpose register R1 to a stack is performed. SP's14 contents are updated by the value by which 4 was subtracted from the current value at the time of activation of this instruction (1000 is updated by 996 as shown in <u>drawing 17</u> (A)). And the contents a of the general-purpose register R1 are written in 996 which is the memory address which SP's14 updated stack pointer shows.
- [0187] <u>Drawing 17</u> (B) shows the motion when 'push R2' which is the instruction which writes out the contents of the general-purpose register R2 to a stack further is performed. SP's14 contents are updated by the value by which 4 was subtracted from the current value at the time of activation of this instruction (996 is updated by 992 as shown in <u>drawing 17</u> (B)). And the contents b of the general-purpose register R2 are written in 992 which is the memory address which SP's14 updated stack pointer shows.
- [0188] Drawing 18 (A) shows the motion when 'pop R2' which is the instruction which takes out the contents of the stack to a general-purpose register R2 is performed. At the time of activation of this instruction, the contents b stored in the memory address 992 which SP's14 stack pointer shows are taken out, and it is stored in a general-purpose register R2. And SP's14 contents are updated by the value with which 4 was added to the current value (drawing 18 (A) it is updated by 996 after activation that it was front [activation] 992 so that it might be shown).
- [0189] <u>Drawing 18</u> (B) shows the motion when 'pop R1' which is the instruction which takes out the contents of the stack to a general-purpose register R1 further is performed. At the time of

activation of this instruction, the contents a stored in the memory address 996 which SP's14 stack pointer shows are taken out, and it is stored in a general-purpose register R1. And SP's14 contents are updated by the value with which 4 was added to the current value (it is updated by 1000 after activation that it was front [ activation ] 996 as shown in drawing 18 (B)). [0190] Thus, it was required to repeat a push instruction and a pop instruction two or more times, and to execute them conventionally, when performing a data transfer by two or more general-purpose registers and stacks. It is because only one register operated the push instruction and the pop instruction with one instruction.

[0191] Therefore, when restoration processing from shunting and the stack to a stack was performed to many registers, increase of the size of object code was caused by the increment in the number of instructions. Moreover, the program execution step also increased and delay of program execution time amount and processing actuation was caused.

[0192] There The instruction set shown below is prepared in CPU of this example.

[0193] pushn %Rs -- (18)

popn %Rd -- (19)

(18) shows description of the assembler of a continuation push instruction, and is an instruction which pushes continuously the contents of n general-purpose registers (n is the natural number of 1 to 16) from %Rs to R0 to a stack. (19) shows description of the assembler of a continuation pop instruction, and is an instruction which carries out pop [ of the n WORD data (n is the natural number of 1 to 16) ] from a stack to the general-purpose register from %Rd to R0 continuously. Each of pushn(s) and popn instructions consists of an operation code and an operand. % Rs shows the register number of Rs in the case of writing from register %Rs to R0 in a stack with the operand of a pushn instruction. % Rd shows the register number of Rd in the case of bringing data from a stack to the register from R0 to %Rd with the operand of a popn instruction.

[0194] The bit map of pushn and a popn instruction is shown in drawing 19. The code which shows %Rs or %Rd goes into the 4-bit low-ranking field, and the register of the arbitration of the general-purpose register which has 16 can be specified. When carrying out a data transfer between a special register and a stack, it carries out through a general-purpose register. [0195] Drawing 20 is a block diagram for explaining the hardware configuration for executing a continuation push instruction (pushn) and a continuation pop instruction (popn). A part required for explanation of a continuation push instruction (pushn) and a continuation pop instruction (popn) is taken out from drawing 1, and it has the composition of having added the part required for explanation. The number same about what points out the same part as drawing 1 is attached. 11 is 16 general-purpose registers of R15 out of [R0] drawing. A general-purpose register 11 performs I/O of a data bus (D DATA BUS) 98 and data. Moreover, the register-select address signal 54 which chooses a register comes from the control circuit block 45. As for 14, the stack pointer is stored by SP. SP's14 value can be outputted to the internal address bus (XA BUS) 78 connected with an address bus (D ADDR BUS) 96 at the input of the 32-bit address adder 30. Another input of the address adder 30 is connected to the offset signal 24 outputted from the control circuit block 45. The output of the address adder 30 is latched by latch (Add LT) 32, and is further outputted to XA\_BUS78 or WW\_BUS76. WW BUS76 is connected to SP's14 input. The 4-bit counter (countx) 46 is in the control circuit block 45, and the number of registers to transmit is counted. Moreover, although not shown by drawing 20 during the control circuit block 45, while there is an instruction register and holding pushn, O \*\* land %Rs of a popn instruction, and %Rd, the control signal according to each instruction is outputted by the

- instruction decoder. 60 in drawing controls I/O of data with the memory (RAM) 50 including external stack area by the bus control unit (BCU), and outputs READ and a WRITE control signal.
- [0196] The actuation at the time of activation of a continuation push instruction (pushn) is explained first.
- [0197] If a continuation push instruction (pushn) is executed, as <u>drawing 4</u> explained, the contents stored in the general-purpose register from the general-purpose register of the register number of %Rs to a general-purpose register R0 will be continuously pushed by the stack.
- [0198] Drawing 21 is a flow chart Fig. for explaining actuation of a pushn instruction.
- [0199] offset of the offset signal 24 is set to -four to the beginning of activation of a pushn instruction. A counter (countx) 46 is cleared by zero and the stack-pointer value stored in SP14 is outputted to XA BUS78 (step 100).
- [0200] Next, the address adder 30 adds the value on XA\_BUS78, and -4, and puts a result into latch (Add LT) 32 (step 101).
- [0201] Latch's (Add\_LT) 32 value is outputted to address bus D\_ADDR\_BUS96. In the control circuit block 45, the difference of %Rs and a counter (countx) 46 held at 4 bits of low order of an instruction register is calculated, and a result is outputted to the register-select address signal 54.
- The register chosen by 54 is put on a data bus (D\_DATA\_BUS) 98, and write-in actuation of external memory (RAM) 50 is carried out (step 102).
- [0202] Step 103 compares %Rs with a counter (countx) 46. When equal, it has completed, and the writing to the external memory of a register writes latch's (Add\_LT) 32 value in SP14 through WW BUS76, and finishes activation of pushn (step 104).
- [0203] When not equal, a counter (countx) is carried out plus 1, latch's (Add\_LT) 32 value is outputted to XA BUS78, and the processing after step 101 is repeated (step 105).
- [0204] Next, the actuation at the time of activation of a continuation pop instruction (popn) is explained.
- [0205] If a continuation pop instruction (popn) is executed, as <u>drawing 4</u> explained, the contents of the stack will be continuously pushed by the general-purpose register of the register number of %Rd from a general-purpose register R0.
- [0206] Drawing 22 is a flow chart Fig. for explaining actuation of a popn instruction.
- [0207] The offset signal 24 is set to +4 to the beginning of a popn instruction. The zero clear of the counter (countx) 46 is carried out, and the value of SP's14 stack pointer is outputted to XA BUS78 and an address bus (D\_ADDR\_BUS) 96 (step 110).
- [0208] Next, the address adder 30 adds the value on XA\_BUS78, and +4, and puts a result into latch (Add LT) 32 (step 111).
- [0209] Next, the read cycle of external memory is performed. The led data are written in a general-purpose register 11 through a data bus (D\_DATA\_BUS) 98. At this time, a counter (countx) 46 is outputted to the register-select address signal 54 by the control circuit block 45 (step 112).
- [0210] Step 113 compares %Rs with a counter (countx) 46. When equal, it has completed, and the writing to the external memory of a register writes latch's (Add\_LT) 32 value in SP14 through WW\_BUS76, and finishes activation of popn (step 114).
- [0211] When not equal, a counter (countx) is carried out plus 1, latch's (Add\_LT) 32 value is outputted to XA\_BUS78 and an address bus (D\_ADDR\_BUS) 96, and the processing after step 111 is repeated (step 115).
- [0212] Thus, the register from %Rs to R0 can be written in a stack by 'pushn %Rs', and the data

of the required number can be returned to the register from R0 to %Rd from a stack by 'popn %Rd'. For example, from the register R3 to R0 can be pushed by one instruction by activation of 'pushn%R3'.

[0213] Still more effective effectiveness occurs by adding one constraint to how using a register in here. That is, although shunting and restoration of a register are needed especially when the programs at interruption processing, the time of a subroutine call, etc. branch to other routines, it is desirable to go a register by routines called, such as an interruption routine besides this time or a subroutine, using order from R0. If it does in this way, the register which does not have the need for evacuation in Rd or Rs is not contained from R0, but shunting or a return of a register can be efficiently performed using a pushn instruction and a popn instruction. Since it has the same function and there is no constraint in an instruction the direction using a register, such constraint does not have any problem and each register can fill it with this example. [0214] Therefore, by using a pushn instruction and popn instruction of this example, pushn and popn are one instruction respectively and the evacuation to the stack in memory from a register and restoration of the data from a stack to a register can perform them. For this reason, object code size and a program execution step are made into the minimum, and only one data transfer of an instruction fetch and a required count is made to require, and an execution cycle can be performed in the minimum cycle. Thereby, processing of an interrupt handler or a subroutine can also attain improvement in the speed.

[0215] On the other hand, the components which realize this are only a count means and easy sequence control, and it can realize with the small gate number and they fit the microcomputer of a one chip.

[0216] Moreover, although this example explained the configuration for performing the continuation push instruction (pushn) at the time of using the register SP 14 only for stack pointers, and a continuation pop instruction (popn), also when using a general-purpose register as a stack pointer, it can apply.

[0217] (Example 2) <u>Drawing 23</u> is the hardware block diagram of the microcomputer of this example.

[0218] This microcomputer 2 is a 32-bit microcontroller. CPU10, ROM52, RAM50 and the RF oscillator circuit 910, the low frequency oscillator circuit 920, a reset circuit 930, the 950 or 8 bit programmable timer 960 of 940 or 16 bit programmable timers of prescalers, the clock timer 970, Intelligent DMA980, a high speed DMA 990, the interruption controller 800, serial interface 810, a bus control unit (BCU) 60, A/D converter 830, D/A converter 840, input port 850, an output port 860, I/O Port 870 and the various buses 92, 94, 96, and 98 which connect them, and various pin 890 grades are included.

[0219] Said CPU10 performs decode of various kinds of instructions only for stack pointers which had and mentioned above SP who is a stack-pointer dedicated register, and activation. This CPU10 has the configuration of an example 1 mentioned above, and functions as said decode means and said activation means.

[0220] Therefore, by the short instruction length, the processing which deals with a stack pointer can be memorized efficiently, and the microcomputer of this example can perform it.
[0221] Moreover, processing of register evacuation or register restoration can be memorized efficiently, and interruption processing and processing of a subroutine call return can be

performed at a high speed.

[0222] The microcomputer of this invention is applicable to personal computer peripheral devices, such as a printer, and various kinds of electronic equipment, such as a pocket device. If

it is made this appearance, since the utilization ratio of memory can build well the information processing circuit which can perform processing in a high speed with an easy configuration, cheap and highly efficient electronic equipment can be offered.

[0223] In addition, what [ not only ] was explained in the above-mentioned example but various deformation implementation is possible for this invention.

#### TECHNICAL FIELD

[Field of the Invention] This invention relates to the electronic equipment constituted using the microcomputer which contains an information processing circuit and said information processing circuit, and this microcomputer.

#### TECHNICAL PROBLEM

Background Art and Problem(s) to be Solved by the Invention] Conventionally, in the microcomputer of a RISC method which can process 32-bit data, the fixed-length instruction of 32-bit width of face was used. The reason is that the time amount which decoding of an instruction takes can be shortened compared with the case where a variable-length instruction is used, and it can make the circuit scale of a microcomputer small if a fixed-length instruction is used.

[0003] However, also in a 32-bit microcomputer, there are also many instructions which are not needed especially 32 bits. Therefore, if 32 bits describes all instructions, the instructions which a redundant part produces in an instruction will increase in number, and the utilization ratio of memory will worsen.

[0004] then, this invention -- the person was performing examination about the microcomputer which processes the fixed-length instruction of bit width of face shorter than the bit width of face of the data which can be processed in order to raise the utilization ratio of memory, without complicating a control circuit.

[0005] However, if 32 bit fixed length's instruction is only made into a 16-bit fixed length, for example, the following troubles will arise.

[0006] That is, in the microcomputer of a RISC method, in order to think the versatility of processing and an instruction set as important, when processing which deals with a stack pointer was performed, said processing was performed using the instruction which makes a general-purpose register applicable to actuation, using one of general-purpose registers as a stack pointer. Therefore, assignment of the general-purpose register currently used as a stack pointer is needed for that of said instruction at the time of describing such processing.

[0007] For example, when the instruction which makes a general-purpose register applicable to actuation describes the processing which transmits the data specified by the memory address which applied the given offset value to the stack pointer to a given register, said offset value, the information which specifies said given register, and the information which specifies the register currently used as a stack pointer are needed for the object code of the instruction.

[0008] Thus, since the information specified by object code increases when describing the processing which deals with a stack pointer with the instruction which makes a general-purpose

register applicable to actuation, it becomes difficult to describe the contents of the instruction by the 16-bit fixed length. Also especially into an instruction, if an instruction length is made into 32 bits here, since an instruction also has many instructions which are not needed 32 bits, the instructions which produce a redundant part will increase in number, and aggravation of the utilization ratio of memory will be invited to an instruction.

[0009] Moreover, since the memory which stores it is also too much needed if an instruction length becomes long, it is desirable that not only a fixed-length instruction but an instruction length can be shortened from a viewpoint of efficient use of memory.

[0010] Moreover, since the instructions which deal with a stack pointer increase in number when performing the program described in the language in which it relates with a stack pointer, for example like C, and the storage region of an auto variable is secured, it is desirable to describe efficiently the instruction which deals with a stack pointer, and to perform it.

[0011] Then, when processing which deals with a stack pointer was performed, by the shortest possible instruction length, the contents of an instruction were described and architecture which can be performed was desired.

[0012] Moreover, especially CPU of a RISC method came to have many general-purpose registers in the interior in order [ latest ] to raise the engine performance. It is because many processings are made to a high speed inside CPU, without accessing memory by having many registers in the interior. Thus, if it has many internal registers, the number of registers which should be evacuated will increase in the case of interruption processing or processing of the register evacuation at the time of a subroutine call, and restoration.

[0013] The conventional example is explained taking the case of shunting of the register which uses it abundantly in case going into a subroutine also in a stack system instruction \*\*\*\* is sufficient hereafter and it carries out, and return instruction.

[0014] Usually, the instruction set of a microcomputer shunts to the stack which prepared the register of CPU in memory, or has the instruction for restoring. There is a thing with an instruction of dedication for that or a thing with a register indirect-addressing instruction. [0015] As a technique about the instruction for [ said ] shunting or restoring, "80386 Pro gramine" (John H.Crawford Patric P.Gelsigner work Iwatani \*\* translation) has the following description about 80386 of Intel.

[0016] That is, it is an instruction which writes a register in a stack. There are push, pusha, and pushad and there are pop, popa, and popad as an instruction for returning data to a register from a stack.

[0017] When writing a register in a stack with a push instruction push EAX A register is specified as an operand like. This is the case of the 32-bit register EAX. It is push when writing Registers EAX, ECX, EDX, and EBX to a stack altogether. EAXpush ECXpush EDXpush A push instruction is repeated like EBX.

[0018] Thus, if it is operating one register at a time with push and a pop instruction, the size of object code will become large, and a program execution step will also increase, therefore program execution time amount and processing actuation will become slower.

[0019] then, all eight general-purpose registers that 80386 has -- a stack -- writing in -- pusha or - pushad An instruction is used. pusha targets the 16 bit register of low order of each of eight registers 32 bits for pushad. It is omissible to repeat a push instruction 8 times by pusha and pushad.

[0020] The same is said of pop, popa, and a popad instruction.

[0021] In order to fetch the disadvantageous point of repeating a push instruction that a program

code becomes long and the whole instruction and to perform it, it is that activation is slow. This point is greatly improved by said pusha and pushad, when writing all of said eight registers in a stack. However, when writing in less than eight register like the case of four, or the case of six, this point does not improve.

[0022] That is, also when all registers are operated with pusha, pushad, popa, and a popad instruction like 80386 and there is no need of evacuating and restoring all the registers, the late long instruction of this cycle must be used. In such a case, although an instruction can be managed with one instruction, the problem of becoming long produces the execution cycle of this instruction.

[0023] Moreover, in case it branches to a subroutine by a call instruction, a return instruction, etc. or returns to the called routine, shunting of a program counter and the restorative processing which are needed as the return point address are needed. In CPU of the conventional RISC method, these processings were realized by software. That is, shunting of said program counter and restorative processing were performed by executing assembler instruction (object code) which described this processing. For this reason, the call instruction and the return instruction caused the increment in object code, and in order to fetch the whole instruction and to perform, they had caused slowdown of execution speed.

[0024] The purpose of this invention is offering the information processing circuit which has the architecture which can describe efficiently the processing which deals with a stack pointer by the short instruction length, and can perform it, a microcomputer, and electronic equipment. [0025] Again Other purposes of this invention are describing processing of register evacuation or register restoration efficiently, and offering interruption processing and the information processing circuit where the processing speed of a subroutine call return is quick, a microcomputer, and electronic equipment.

# **MEANS**

[Means for Solving the Problem] This invention is characterized by to have the object code which makes an implied operand the stack-pointer dedicated register only used for stack pointers, and this stack-pointer dedicated register, to decode the object code of the instruction group only for stack pointers the processing based on this stack-pointer dedicated register was described to be, and to include a decode means output a control signal based on this object code, and an activation means perform said instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[0027] Although the thing of the program code obtained as a result of translating object code into an absolute language by the compiler generally in here is said, in this invention, it is used with the large concept which contains the program code described in the absolute language not related in the paddle by the compiler.

[0028] The information processing circuit of this invention has a stack-pointer dedicated register only for stack pointers, and it is constituted so that decode of the instruction group only for stack pointers which makes this stack-pointer dedicated register applicable to actuation, and activation may be performed.

[0029] Since said instruction group only for stack pointers has the operation code of the dedication for dealing with a stack-pointer dedicated register, it does not need the information for specifying a stack pointer for the operand of object code. In other words, said instruction group

only for stack pointers makes the stack-pointer dedicated register the implied operand. For this reason, compared with the case where a stack pointer is operated using the instruction which makes one of the general-purpose registers addressing to a rate, and makes a general-purpose register applicable to actuation at a stack pointer, the instruction which deals with a stack pointer by the short instruction length can be described.

[0030] Therefore, according to this invention, the information processing circuit which can describe and perform processing which deals with a stack pointer by the short instruction length can be offered. Moreover, the good information processing circuit of the utilization ratio of the memory which memorizes an instruction can be offered.

[0031] This invention includes the load instruction to which said instruction group only for stack pointers has transfer register specific information in object code. When said decode means decodes said load instruction and said activation means executes said load instruction, Either [at least] the data transfer from the first area to the first given given register on memory, or the data transfer from said first given register to said first given area It is characterized by carrying out based on the register address specified by the memory address specified with said stack-pointer dedicated register, and said transfer register specific information.

[0032] Said load instruction included in said instruction group only for stack pointers in here is an instruction which performs a data transfer between memory and a register, and is a concept including either [ at least ] the transfer to a register from memory, or the transfer to memory from a register. In addition, it is the concept which also contains address data regardless of the contents of data. A memory address means the address for pinpointing the area on the memory in the case of a transfer.

[0033] Since said load instruction has the operation code of the dedication for making a stack-pointer dedicated register applicable to actuation, it does not need the information for specifying a stack pointer for the operand of object code. For this reason, when making data transfer processing perform between the area on the memory which has the memory address related with the stack pointer, and a register, a short instruction length can describe.

[0034] This invention includes the offset information said whose load instruction is the information about the offset for specifying the address of said first area on said memory in object code, and said activation means is characterized by specifying said memory address using the contents and said offset information on said stack-pointer dedicated register.

[0035] In here, what specified the offset value by the direct immediate is sufficient as offset information, and the case where it specifies indirectly like [ in the case of specifying the addresses, such as a register with which the offset value was stored ] is sufficient as it. When said load instruction including offset information is executed, said memory address which is needed in case it is a transfer is specified based on the contents and offset information on a stack-pointer dedicated register.

[0036] Therefore, when making data transfer processing perform between the area on the memory which has the memory address specified based on a stack pointer and said offset information, and a register, a short instruction length can describe.

[0037] Moreover, according to this invention, also in the information processing circuit of the structure where a stack pointer always puts the word boundary, for example, it becomes possible by specifying suitable offset information to specify the area of the arbitration on a stack. For this reason, according to the size of data, it can store in a stack efficiently, and improvement in the utilization ratio of a stack can be aimed at.

[0038] Including the immediate offset information that said offset information was given by the

immediate, and the data size information about the size of the given data on memory, based on said immediate offset information and said data size information, said activation means carries out the left logic shift of said immediate offset information, and generates an offset value, and this invention is characterized by to specify said memory address with the value adding the contents and said offset value of said stack-pointer dedicated register.

[0039] In here, immediate offset information means what specified the offset value by the direct immediate. Moreover, data size information means the size of the memory top data which should be transmitted. Usually, data size is expressed with 2n (n is three or more), such as 8-bit cutting tool data, and 16 bits halfword data, 32-bit WORD data. The address on memory is given per cutting tool, halfword data are set on a halfword boundary, and WORD data are set to the word boundary. Therefore, 1 bit of the low order of the memory address of halfword data is set to 0, and 2 bits of the low order of the memory address of WORD data are set to 00. Since the address of a stack pointer has pointed out the word boundary, 1 bit of the low order of the offset value in the case of generating the memory address of halfword data is set to 0, and 2 bits of the low order of the offset value in the case of generating the memory address of WORD data are set to 00.

[0040] Moreover, a left logic shift shifts the bit string of data on the left, and means the shift in which 0 goes into the vacancy bit (shift in bit) which comes out to the right-hand side of data by shift

[0041] According to this invention, since the left logic shift of said offset immediate information is performed based on data size, with data size, the bit of the low order decided uniquely can be omitted and immediate offset information can be described. Therefore, immediate offset information can be specified efficiently, and when it is data sizes other than a cutting tool, compared with the case where it specifies as it is, assignment becomes possible at a larger offset value.

[0042] Moreover, by using this instruction, the suitable boundary location according to the data size will be chosen at the time of the writing to the memory of data, and read-out.

[0043] This invention is characterized by changing the contents of said stack-pointer dedicated register based on said migration information, in case said decode means decodes said stack-pointer migration instruction and said activation means executes said stack-pointer migration instruction for said instruction group only for stack pointers to have migration information in object code, and move a stack pointer to it. [0044] Since said stack-pointer migration instruction has the operation code of the dedication for making a stack-pointer dedicated register applicable to actuation, it does not need the information for specifying a stack pointer for the operand of object code. For this reason, a short instruction length can describe to move a stack. Therefore, the amount of description of the instruction at the time of processing the data memorized by relating with the processing of data and the stack pointer which are stored in the stack is reducible.

[0045] Since migration of a stack can carry out easily according to this invention, it is effective when processing by securing stack area which is different in an especially different routine, respectively. That is, by performing processing to which a stack pointer is moved for every routine, it becomes addressable over a wide range field.

[0046] This invention is characterized by processing at least one side of the processing to which said instruction-execution means subtracts said immediate migration information from the contents of the processing adding said immediate migration information and contents of said stack-pointer dedicated register, and said stack-pointer dedicated register including the

immediate migration information that said migration information was given by the immediate. [0047] According to this invention, only a part to have specified the value of a stack pointer for immediate migration information can describe the upper part or the processing to which it is made to move caudad by the short instruction length.

[0048] This invention contains two or more registers which were able to be continuously set in order. Said instruction group only for stack pointers Either [ at least ] the continuation push instruction which has two or more register specific information in object code, or a continuation pop instruction is included. Said decode means decodes either [ at least ] said continuation push instruction or a continuation pop instruction. When said instruction-execution means executes either [ at least ] said continuation push instruction or said continuation pop instruction, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack It is characterized by attaining to the memory address specified according to the contents of said stack-pointer dedicated register, and carrying out based on said two or more register specific information. [0049] As for a push, taking out data from said stack as it is pop means accumulating and storing data in the stack prepared in memory. With the processing pushed in here, and the processing which carries out pop, said storing and processing of ejection, and an update process of the stack pointer accompanying it are included. The usual information processing circuit has the push instruction for storing data and the address in a stack from the register of 1, and the pop instruction which takes out the contents of the stack to a register. This push instruction and a pop instruction update the stack pointer accompanying an exchange of the data of a register and a stack, and this exchange.

[0050] Therefore, in exchanging data etc. by two or more registers and stacks, it is necessary to carry out multiple-times activation of these instructions.

[0051] However, according to this invention, if said continuation push instruction and said continuation pop instruction are executed, the same effectiveness as the case where multipletimes activation of the case where multiple-times activation of the push instruction is carried out continuously, or the pop instruction is carried out continuously will be acquired. That is, renewal of the stack pointer accompanying an exchange and this exchange of the data between two or more registers and a stack can be performed with one instruction. For this reason, when performing the data transfer between two or more registers and a stack, it can prevent object code size increasing by repeating a push instruction or a pop instruction. Moreover, improvement in the processing speed of interruption processing and a subroutine call return can be aimed at, without avoiding that a program execution step becomes long and consuming a useless cycle. [0052] This invention contains n general-purpose registers specified by the register numbers from 0 to n-1. One [ at least ] object code of said continuation push instruction and a continuation pop instruction as said two or more register specific information The last register number as which either of said register numbers was specified is included. At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing in which said activation means carries out a multiple-times push continuously to the stack prepared in memory from two or more registers to the register specified by said last register number from a register 0, and said stack It is characterized by carrying out based on the memory address specified according to the contents of said stack-pointer dedicated register. [0053] Usually, when there are two or more general-purpose registers, it has the address for specifying a register. By this invention, said register is specified by the register number followed

from 0 to n-1.

[0054] According to this invention, either [ at least ] processing which pushes data between two or more registers and memory which were followed from a register 0 to said last register number, or processing which carries out pop is performed by specifying the register number of arbitration as said last register number. Therefore, in the program execution which has structure which uses a register in an order from the register of a register number 0, shunting and restoration of a register can be performed efficiently.

[0055] The write-in means which writes the contents of the register of two or more of said registers either given [ this invention ] in said activation means in the stack prepared in memory based on the memory address specified with said stack-pointer dedicated register, A count count means of writing to count the count of writing to said stack by said write-in means, A comparison means to compare the value of said count of writing counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said write-in means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place. It controls so that the first input of said adder serves as the contents of the stack-pointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the write-in address-generation means after it ] input-control means controlled to write in and to become the address, The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of the register specified with the value which subtracted said count of writing from said two or more register specific information Based on the comparison result of said comparison means, it is characterized by controlling two or more writing to said stack from a register and write-in termination including the means written in said stack based on said write-in memory address. [0056] Moreover, this invention reads the contents of the stack by which said instructionexecution means was formed in memory based on the memory address specified with said stackpointer dedicated register. A read-out means to store in the either given register of two or more of said registers, A count count means of read-out to count the count of read-out from said stack by said read-out means, A comparison means to compare the value of said count of read-out counted with said count means and said two or more register specific information is included. A write-in memory address generation means by which said read-out means generates the write-in memory address for adding the first input and second input with an adder, and specifying a writing place. It controls so that the first input of said adder serves as the contents of the stackpointer dedicated register at the time of activation initiation of the instruction only for continuation. The first [ which was generated by the read-out address-generation means after it ] input-control means controlled to read and to become the address, The second input-control means which outputs the offset value when writing 1 word in the second input of said adder from said stack, The contents of said stack are read based on said read-out memory address. Based on the comparison result of said comparison means, it is characterized by controlling read-out and read-out termination of the contents of said stack including a read-out means to store in the register specified based on said count of writing.

[0057] If it does in this way, the restoration to two or more registers specified with the value which continued from shunting or the stack to the stack of two or more registers systematically specified with the continuous value is realizable only by the count means and easy sequence control. Therefore, since it is realizable in the information processing circuit of the small gate number, it is suitable for the microcomputer of a one chip etc.

[0058] This invention contains the program counter register only for program counters. The branch instruction said whose instruction groups only for stack pointers are the instruction which branches to a subroutine, and a return instruction from said subroutine is included. When said decode means decodes said branch instruction and said instruction-execution means executes said branch instruction, At least one side of the return to shunting of the contents of said program counter register to the second given area of the stack prepared in memory, and the program counter register of the contents of said second area It is characterized by including the means performed based on the memory address specified with said stack-pointer dedicated register, and a means to update the contents of said stack-pointer dedicated register based on said shunting and said return.

[0059] In here, interruption processing, exception handling, a debugging manipulation routine, etc. are included with a subroutine. Therefore, with the instruction which branches to a subroutine, the software interrupt instruction for branching to an instruction, interruption processing, exception handling, a debugging manipulation routine, etc. which call a subroutine etc., a software debugging interruption instruction, etc. are included. Moreover, the return instruction from interruption processing, exception handling, a debugging manipulation routine, etc. is included in a return instruction from a subroutine.

[0060] Usually, when returning from the case where it branches to a subroutine, or said subroutine, shunting and a return of a program counter are needed.

[0061] In this invention, in case the instruction which carries out a return from the activation and the subroutine of an instruction which branch to said subroutine is executed, shunting and a return of said program counter are also performed to coincidence. That is, the information processing circuit of this invention has circuitry which can perform shunting and a return of a program counter with the instruction which branches to a subroutine, and any 1 instruction of the return instruction from said subroutine. For this reason, shunting of said program counter which is needed in connection with the return from branching and the subroutine to a subroutine, and an instruction of a return become unnecessary, and the number of instructions can be reduced. Moreover, improvement in the processing speed at the time of branching can be aimed at to other routines, such as a subroutine call return, without consuming a useless cycle.

[0062] Moreover, when a software interrupt instruction is generated, shunting and the return holding the current condition of information processing circuits, such as CPU, of a processor status register are also needed. Therefore, in a software interrupt instruction etc., it is desirable that it is made to perform shunting and a return of a processor status register to coincidence at the time of activation of this instruction.

[0063] This invention is an information processing circuit containing the stack pointer assigned to two or more registers which were able to be continuously set in order, and one of general-purpose registers. The object code of one [ at least ] instruction of the continuation push instruction which has two or more register specific information in object code, and a continuation pop instruction is decoded. When at least one side of a means to output a control signal based on this object code, and said continuation push instruction and said continuation pop instruction is performed, At least one side of the processing which carries out multiple-times pop succeeding said two or more registers from the processing which carries out a multiple-times push from said two or more registers continuously to the stack prepared in memory, and said stack It is characterized by including the means performed based on the memory address specified according to the contents of said control signal and said stack-pointer dedicated register, and said two or more register specific information.

[0064] This invention relates to said continuation push instruction and said continuation pop instruction in the case of using a general-purpose register as a stack pointer.

[0065] According to this invention, if said continuation push instruction and said continuation pop instruction are executed, the same effectiveness as the case where multiple-times activation of the case where multiple-times activation of the push instruction is carried out continuously, or the pop instruction is carried out continuously will be acquired. That is, renewal of the stack pointer accompanying an exchange and this exchange of the data between two or more registers and a stack can be performed with one instruction. For this reason, when performing the data transfer between two or more registers and a stack, it can prevent object code size increasing by repeating a push instruction or a pop instruction. Moreover, improvement in the processing speed of interruption processing and a subroutine call return can be aimed at, without avoiding that a program execution step becomes long and consuming a useless cycle.

[0066] It is characterized by the information processing circuit of \*\*\*\*\*\* being a RISC method.

[0067] The information processing circuit of a RISC method is designed for the purpose of miniaturizing hardware and attaining improvement in the speed. For this reason, it has many general-purpose registers and reduction of the number of instructions is aimed at by extracting an instruction set to the high thing of versatility.

[0068] Therefore, in the information processing circuit of a RISC method, the stack pointer was assigned to the general-purpose register, and when a stack pointer was treated, it was processing using the instruction set treating a general-purpose register. However, by such approach, an instruction length becomes large, and the utilization ratio of memory is not good.

[0069] According to this invention, in the information processing circuit of a RISC method, instruction lengths can be reduced and the utilization ratio of memory can be gathered.

[0070] The information processing circuit of this invention decodes a fixed-length instruction, and is characterized by performing executive operation based on this instruction.

[0071] If a fixed-length instruction is used, the time amount which decoding of an instruction takes can be shortened compared with the case where a variable-length instruction is used, and the circuit scale of an information processing circuit can be made small. When adopting a fixed-length instruction, in order to prevent making a redundant part to an instruction and to use memory efficiently, the number of bits required for each instruction has little dispersion, and its shorter possible one is desirable.

[0072] According to this invention, generally, an instruction length can shorten the instruction length of an instruction which deals with the stack pointer which tends to become long. Therefore, even if it is the case where a fixed-length instruction is adopted, it can prevent making

a redundant part to an instruction, and memory can be used efficiently.

[0073] The microcomputer of this invention is characterized by including a means to perform I/O with the information processing circuit of this invention and storage means which were mentioned above, and the exterior.

[0074] According to this invention, processing speed can offer a quick microcomputer with the sufficient utilization ratio of memory.

[0075] The microcomputer of this invention is characterized by performing the program of the language which has the structure where relate with said stack pointer and the storage region of an auto variable is secured.

[0076] There is C as language which has the structure where relate with a stack pointer and the storage region of an auto variable is secured and to carry out. When the microcomputer of this

invention processes the program of such language, processing speed and the utilization ratio of memory can be raised effectively.

[0077] The electronic equipment of this invention is characterized by including the microcomputer of this invention mentioned above.

[0078] According to this invention, since processing speed builds in the quick good information processing circuit of the utilization ratio of memory, cheap and highly efficient electronic equipment can be offered.

[0079]

[Embodiment of the Invention] Hereafter, this example is explained based on a drawing. [0080] (Example 1)

(1) By the architecture of a load store mold, CPU of configuration this example of CPU of this example executes almost all instructions in 1 cycle with a pipeline. All instructions are described by the 16-bit fixed length, and the instruction which CPU of this example processes has realized very small object code size.

[0081] Especially CPU of this example is constituted so that the instruction set of the instruction group only for stack pointers which has a register only for stack pointers in order to describe efficiently the processing which deals with a stack pointer and to perform it, and has the object code which makes this stack-pointer dedicated register an implied operand can be decoded and performed.

[0082] <u>Drawing 1</u> is drawing for explaining the outline of the circuitry of CPU of this example. [0083] A book CPU 10 contains a register set including SP14 who are a general-purpose register 11, PC12 with which the program counter is stored, the processor status register (PSR) 13, and a register only for stack pointers, an instruction decoder 20 and the immediate generation machine 22, the address adder 30, ALU40, the PC incrementer 44 and the various internal buses 72, 74, 76, and 78, the various internal signal lines 82, 84, and 86, and 88 grades.

[0084] Said instruction decoder 20 decodes the inputted object code, performs processing required in order to execute this instruction, and outputs a required control signal. In addition, this instruction decoder 20 functions also as said decode means to decode the object code of the instruction only for said stack pointers, and to output a control signal based on this instruction. [0085] The immediate generation machine 22 generates the immediate data of 32 bits used at the time of activation based on the immediate contained in object code, or generates the constant data of 0 [ required for activation of each instruction ], \*\*1, \*\*2, and 4 [ \*\*]. The PC incrementer 44 updates the program counter stored in PC12 based on the execution cycle of an instruction. In case the address adder 30 adds the immediate data generated with the information stored in various registers, or the immediate generation vessel 22 and reads data from memory, it generates required address data. ALU40 performs math processing and logical operation. [0086] Moreover, this CPU contains various buses and a signal line inside. PA BUS72 and PB BUS74 have the function to transmit the input signal of ALU40 etc. WW BUS76 has the function which takes out the result of an operation of ALU40, and is transmitted to a generalpurpose register. XA BUS78 has the function to transmit the address data taken out from the general-purpose register 11 or SP14 etc. The IA signal line 82 transmits address data to external I ADDR\_BUS92 from each part inside CPU. The DA signal line 84 transmits address data to external D ADDR BUS96 from each part inside CPU. The DIN signal line 86 transmits data to each part inside CPU from D DATA BUS98 of the CPU exterior. The DOUT signal line 88 transmits data to external D DATA BUS98 from each part inside CPU. IA input change-over 83 switches the various signals (PA BUS72, WW BUS76, PC12, PC+2) outputted to the IA signal

line 82. The DOUT input change-over 89 switches the various signals (PA\_BUS72, WW BUS76, PC12, PC+2) outputted to the DOUT signal line 88.

[0087] Moreover, said each part of CPU10 functions based on the control signal which said instruction decoder 20 outputs also as said activation means to execute an instruction and to perform the instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[0088] A book CPU 10 performs an exchange of the exterior and a signal through the instruction address bus (I\_ADDR\_BUS) 92 for the 16-bit instruction data bus (I\_DATA\_BUS) 94 and an instruction data access, the 32-bit data bus (D\_DATA\_BUS) 98, the data address bus (D\_ADDR\_BUS) 96 for a data access, and the control bus that is not illustrated for a control signal.

[0089] (2) the explanation of a register set in which this example carries out CPU \*\* -- explain a part required about the outline of the register set which CPU of this example has next. [0090] The register set which CPU of this example has in <u>drawing 2</u> is shown. CPU of this example has the register set which contains 16, and PC12, PSR13, SP14, ALR (arithmetic operation low register)15 that is not illustrated and AHR (arithmetic operation high register)16 which is not illustrated for a general-purpose register 11.

[0091] said general-purpose register 11 -- functional -- a 32-bit equivalent register -- it is -- R0 to R15, and naming \*\*\*\*\*. This general-purpose register 11 is used at the time of a data operation and address computation.

[0092] Moreover, PC12 is the incremental counter of 32 bit length, and holds the program counter which is the address of the instruction under current activation. In the text, when pointing out a register name, it is called PC, and it is called a program counter when putting the value stored in PC.

[0093] Direct access of this PC12 cannot be carried out by a load instruction etc. If a call instruction, an int instruction, interruption, and an exception occur, a program counter will be read from PC12 and will be evacuated to a stack. Thus, it will fly, if branch instruction is executed, and the point address is set as PC. It is also the same as when branching with a conditional-branching instruction. And the return point instruction address is read by a ret instruction and reti instruction from a stack, and returns to PC12 with them.

[0094] PSR (processor status register)13 is a 32-bit register to which the flag is assigned, and holds the current condition of CPU. If an int instruction, interruption, an exception, etc. occur, in case it will branch to each manipulation routine, the condition of PSR at that time is evacuated to a stack. Conversely, by activation of a reti instruction, the evacuated value returns to PSR. [0095] SP14 is a register only for [ of 32 bits ] stack pointers, and the stack pointer which puts the head address of a stack is stored. In the text, when pointing out a register name, it is called SP, and it is called a stack pointer when putting the value stored in SP. However, since the stack pointer has always pointed out the boundary of WORD, 2 bits of the low order of said stack pointer are always 0.

[0096] This stack pointer is updated with activation of the various instructions included in the instruction group only for stack pointers currently prepared by this example, and generating of a trap. There are an instruction which branches to other routines, such as a call instruction and a ret instruction, as an instruction only for stack pointers which updates a stack pointer, a stack-pointer migration instruction, a pushn instruction, a popn instruction, etc. For example, if a call instruction is executed, the decrement (-4) of the stack pointer will be first carried out only for wordsize (4), and PC12 will be evacuated to a stack. Moreover, if a ret instruction is executed,

the return point address will be conversely loaded to PC from a stack, and the wordsize part increment (+4) of the stack pointer will be carried out. When an int instruction is executed, or it interrupts and an exception etc. occurs, the value of PC or PSR is evacuated to a stack in the following procedures.

[0097] 1) Evacuate PC to the head address of the stack to which it is pointed out with SP=SP-42 stack pointer.

[0098] 3) Evacuate PSR to the head address of the stack to which it is pointed out with SP=SP-44 stack pointer.

[0099] If a reti instruction is executed, processing contrary to the above will be performed and CPU will return to a former condition. Thus, activation of a call instruction, a ret instruction, and an int instruction updates a stack pointer based on this activation. About the detail of each instruction, it mentions later.

[0100] Moreover, in this example, a trap means what doubled the exception generated by activation of interruption and the instruction which are generated in activation of an instruction asynchronous. If a trap occurs, CPU will read a vector table from a trap table, after evacuating a program counter (PC) and a processor status register (PSR) to a stack, and will branch to the manipulation routine corresponding to the trap. With generating of a trap, IE bit in PSR (enable [interruption]) is cleared, and generating of mask possible interruption beyond it is forbidden. In order to enable again external interruption in which a mask is possible, 1 is written in and set as IE bit of PSR using the load instruction to PSR.

[0101] A reti instruction is used in order to return to the original routine from trap processing. If a reti instruction is executed, CPU will branch to the return address while it is read from a stack in order of PSR and PC and returns PSR to the original value. In addition, there are a debugging exception, an address irregular train exception, an overflow exception, a division-by-zero exception, etc. as exception.

[0102] Explanation is omitted about ALR (arithmetic operation low register)15 and AHR (arithmetic operation high register)16.

[0103] The special registers PSR13, SP14, ALR15, and AHR16 which CPU has can perform data transfer between general-purpose registers using a load instruction. Each register has a special register number and is accessed using this number.

[0104]

A special register name Special register number The description approach processor status register of an assembler 0 % PSRSP 1 % SP arithmetic operation low register 2 % An ALR arithmetic operation high register From the lower part of the field which followed memory in the already kicked temporary storage, data accumulate a 3 %AHR (3) stack and the explanation stack about a stack pointer on ledged, and they are memorized. The stack pointer shows the address of the data memorized, the top, i.e., last, of a stack memory.

[0105] General actuation of a stack pointer is explained using  $\underline{\text{drawing 3}}$ .

[0106] 100 of drawing 3 expresses the stack area established in memory. Supposing a shadow area 102 is data stored at the end, the stack pointer stored in SP14 shows the memory address 1000 of these data. In addition, the lower part field 104 of a shadow area 102 is a field where data are already stored, and the upper part field 106 of a shadow area 102 shows the field where data will be stored from now on.

[0107] Since the stack pointer has always pointed out the boundary of WORD, when writing information in a stack, it stores information in the location where only 4 moves upwards the stack pointer with which SP14 was stored, and this stack pointer points to it. Moreover, when

taking out the information stored in the stack, the information on the address which current [SP / 14] shows is taken out, and only 4 moves downward the stack pointer stored in SP14. Thus, the stack pointer shows the storing address of the information always stored in the stack finally. [0108] (4) Although a general-purpose register is used as a stack pointer in CPU of the explanation usual RISC method about the instruction group only for stack pointers, in this example, it has SP14 who is a register only for stack pointers, and is set as the actuation object of said instruction group only for stack pointers.

[0109] Said instruction group only for stack pointers is the generic name of two or more instructions which make an implied operand SP14 who is a register only for stack pointers, and operate it by being with SP14. This instruction group only for stack pointers includes the instruction which branches to other routines, such as SP relative load instructions (ld etc.), a stack-pointer migration instruction (add, sub), instructions (call etc.) that branch to a subroutine, and return instructions (ret etc.), a continuation push instruction (pushn), and a continuation pop instruction (popn).

[0110] Since it is the instruction only for stack pointers, I hear that that it is common in the instruction of \*\*\*\*\*\*\* has the unnecessary information for specifying a stack pointer to object code, and it is in it. Therefore, the effectiveness that a short instruction length can describe the processing using a stack pointer efficiently is also common.

[0111] Moreover, if these instructions are used, information memorized by the stack prepared in memory can be processed efficiently. Moreover, interruption processing and processing of a subroutine call return can be performed efficiently.

[0112] Here, the busy condition of the already kicked stack and the condition of a stack pointer are explained to the example of use and memory of the instruction only for said stack pointers in case a subroutine is called using drawing 4. The main program 500 and subroutine 520 of drawing 4 are the program described by the object code which the C compiler created. 540 shows the condition of the stack on memory. 502 shows that processing which uses general-purpose registers R0-R3 is performed. 506 shows the subroutine call instruction. The back stack pointer (SP) with which the instruction before the subroutine call instruction with which a subroutine call instruction is executed by the main program 500 (i.e., before being shown in 504) was executed presupposes that the address of \*\* on the stack 540 on memory was pointed out. If said subroutine call instruction is executed, control of activation will be crossed to a subroutine 520. At this time, the instruction (call instruction) which branches to the subroutine which is the instruction only for said stack pointers is executed by this example. As for the value of a stack pointer (SP), activation of this instruction stores the return address to a main program in the area 544 on the stack to which the increment only of -4 was carried out (refer to \*\*SP of drawing 4), and this stack-pointer \*\*SP has pointed it out automatically.

[0113] And in a subroutine 520 side, processing which transmits to a stack the value stored in the general-purpose registers R0-R3 currently used for the beginning of activation by the main program is performed. 524 shows the continuation push instruction (pushn) which is an instruction only for stack pointers which performs processing which shunts to a stack the value stored in general-purpose registers R0-R3. If this instruction is executed, the value stored in general-purpose registers R0-R3 will be continuously transmitted to a stack, and it is stored in a stack 540 as shown in 550 of drawing 4. The stack pointer (SP) has pointed out 546 as activation of this processing finishes (524\*\*) (\*\*SP).

[0114] Next, in a subroutine 520, the auto variable area used by the subroutine is secured. The add instruction shown in 526 is a stack-pointer migration instruction which is an instruction only

for stack pointers, and secures the stack area which is made to move a stack pointer up and is used by the subroutine 520. If this instruction is executed, only X cutting tool will move a stack pointer (SP) to the upper location 548 (\*\*SP), and the field of the auto variable which the subroutine shown in notes 2 uses will be secured.

[0115] It is shown that 528 performs processing which used an auto variable and general-purpose registers R0-R3 by the subroutine 520. At this time, the location of a stack pointer has pointed out \*\*SP, and loading of an auto variable is performed by being with the load instruction only for SPs which is an instruction only for stack pointers.

[0116] 529 shows said SP load instruction which transmits the auto variable S1 stored on memory to a general-purpose register R1. Said auto variable S1 is stored in the location which has Y bytes of offset value from a stack pointer (\*\*SP). Since a stack pointer does not move in the midst of processing of 528 of a subroutine as mentioned above, the memory address of an auto variable is specified with a stack-pointer + offset value, and can perform the exchange with a general-purpose register efficiently using the load instruction only for said SPs.

[0117] Moreover, before returning from a subroutine 520 to a main program 500, the value of the general-purpose registers R0-R3 which had shunted to the stack is returned to general-purpose registers R0-R3, and it must be made for a stack pointer to have to point out the area 544 where the return address to a main routine is stored. Therefore, the stack pointer to which it was made to move with the stack-pointer migration instruction of 526 is first returned to the location of a basis. The sub instruction shown in 530 is a stack-pointer migration instruction which is an instruction only for stack pointers, and moves a stack pointer caudad. Activation of this instruction moves a stack pointer to 546 (refer to \*\*SP). Next, processing which restores the information 550 stored in the stack to general-purpose registers R0-R3 is performed. 532 shows the continuation pop instruction (popn) which is an instruction only for stack pointers which performs processing which transmits the information on a stack to general-purpose registers R0-R3. If this instruction is executed, the value 550 stored in the stack will be continuously transmitted to general-purpose registers R0-R3, and it is stored in a stack 540 as shown in 550 of drawing 4. activation of this processing -- finishing (532\*\*) -- the stack pointer has pointed out 544 (refer to \*\*SP).

[0118] 534 shows the return instruction. If said return instruction is executed, control of activation will be crossed to a main program 500. At this time, the return instruction (ret instruction) which is an instruction only for said stack pointers is executed by this example. If this instruction is executed, it will branch to the instruction which the return address to the main program stored in the stack area which \*\*SP points out shows, namely, will return to the instruction 507 next to a main program 500. And the value of a stack pointer moves to the head area of a stack where the increment only of +4 is carried out, and a main program 500 uses it automatically (refer to \*\*SP of drawing 4).

[0119] The circuitry for executing explanation and this instruction of an instruction about each [ said ] instruction only for stack pointers below, respectively, the motion at the time of activation, etc. are explained to a detail.

[0120] (5) Create the object code a C compiler relates the field of an auto variable with a stack pointer, and it is remembered that carried out the stack-pointer relative load instruction above-mentioned. Specifically, the C compiler is the specification which secures Y bytes of field of an auto variable from a stack pointer in the place whose offset is X.

[0121] <u>Drawing 5</u> is drawing for explaining the processing which transmits the auto variable on memory to a register. The auto variable a is [ halfword data and auto variable d-g of WORD data

and the auto variables b and c ] cutting tool data. The stack pointer stored in SP shows 1000 which is the address of the head field of the field 600 where the auto variable on a stack is stored. The area on the stack which makes said stack pointer a memory address as area for storing the auto variable a The area on the stack which makes a memory address a stack pointer +2 and a stack pointer +4 as area for storing the auto variables b and c, respectively The area on the stack which makes a memory address a stack pointer +5, a stack pointer +6, a stack pointer +7, and a stack pointer +8 as area for storing auto variable d-g, respectively is secured. And in case given processing is performed, data transfer processing is needed between the auto variable specified by the memory address of a stack-pointer + offset value, and a general-purpose register.

[0122] In CPU of this example, in order for short object code to describe such transfer processing and to perform it efficiently, the instruction set shown below is prepared as an SP relative load instruction which is one of the instructions only for stack pointers.

[0123]

```
ld.b %Rd [%sp+imm6] -- (1)
```

ld.ub %Rd [%sp+imm6] -- (2)

ld.h %Rd [%sp+imm7] -- (3)

ld.uh %Rd [%sp+imm7] -- (4)

ld.w %Rd [%sp+imm8] -- (5)

ld.b [%sp+imm6] %Rs -- (6)

ld.h [%sp+imm7] %Rs -- (7)

ld.w [%sp+imm8] %Rs -- (8)

(1) - (8) describes instruction code by the assembler. (1) is an instruction which carries out the sign escape of the cutting tool data from a stack, and is transmitted to a register. (2) is an instruction which carries out the zero escape of the cutting tool data from a stack, and is transmitted to a register. (3) is an instruction which carries out the sign escape of the halfword data from a stack, and is transmitted to a register. (4) is an instruction which carries out the zero escape of the halfword data from a stack, and is transmitted to a register. (5) is an instruction which transmits WORD data to a register from a stack. (6) is an instruction which transmits cutting tool data to a stack from a register, (7) is an instruction which transmits halfword data to a stack from a register, and (8) is an instruction which transmits WORD data to a stack from a register.

[0124] [%sp+imm6], [%sp+imm7], and [%sp+imm8] express immediate offset information, respectively, the offset value generated based on this immediate offset information at the time of activation and the value of the stack pointer stored in SP14 are added, and a memory address is generated. When the data size of the data on memory is a cutting tool, [%sp+imm7 of [%sp+imm6]] is immediate offset information when the data size of the data on memory is a halfword, in case the data size of the data on memory of [%sp+imm8] is WORD. These all <A mentioned later

```
HREF="/Tokujitu/tjitemdrw.ipdl?N0000=237&N0500=1E_N/;>??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??6>;;??
```

#### DESCRIPTION OF DRAWINGS

[Brief Description of the Drawings]

[Drawing 1] It is drawing for explaining the outline of the circuitry of CPU of this example.

[Drawing 2] The register set which CPU of this example has is shown.

[Drawing 3] It is drawing for explaining general actuation of a stack pointer.

[Drawing 4] It is drawing for explaining the busy condition of the stack already kicked by the example of use and memory of the instruction only for stack pointers, and the condition of a stack pointer.

[Drawing 5] It is drawing for explaining the processing which transmits the auto variable on memory to a register.

[Drawing 6] Drawing 6 (A) and (B) are drawings having shown the bit field of SP relative load instruction and a general-purpose load instruction.

[Drawing 7] It is a flow chart Fig. for explaining actuation of SP relative load instruction of WORD data read-out.

[Drawing 8] It is a flow chart Fig. for explaining actuation of SP relative load instruction of WORD data writing.

[Drawing 9] Drawing 9 (A) - (F) is drawing for explaining the busy condition of the stack on the memory by each routine in case a program is performed over two or more routines, and the condition of a stack pointer.

[Drawing 10] Drawing 10 (A) and (B) are drawings having shown the bit field of a stack-pointer migration instruction and general-purpose operation instruction.

[Drawing 11] It is a flow chart Fig. for explaining actuation of an addition stack-pointer migration instruction.

[Drawing 12] It is a flow chart Fig. for explaining actuation of a subtraction stack-pointer migration instruction.

[Drawing 13] It is drawing for explaining control of the program execution by a call instruction and ret instruction.

[Drawing 14] It is drawing having shown the bit field of PC relative subroutine call instruction.

[Drawing 15] It is a flow chart Fig. for explaining actuation of PC relative subroutine call instruction.

[Drawing 16] It is a flow chart Fig. for explaining actuation of a ret instruction.

[Drawing 17] Drawing 17 (A) and (B) are drawings having shown typically the motion at the time of a push instruction execution.

[Drawing 18] Drawing 18 (A) and (B) are drawings having shown typically the motion at the time of a pop instruction execution.

[Drawing 19] The bit map of pushn and a popn instruction is shown.

[Drawing 20] It is a block diagram for explaining the hardware configuration for executing a continuation push instruction (pushn) and a continuation pop instruction (popn).

[Drawing 21] It is a flow chart Fig. for explaining actuation of a pushn instruction.

[Drawing 22] It is a flow chart Fig. for explaining actuation of a popn instruction.

[Drawing 23] It is the hardware block diagram of the microcomputer of the gestalt of this operation.

[Description of Notations]

2 Microcomputer

## Machine English translation of JP 10-091443A

- 10 CPU
- 11 General-purpose Register
- 12 PC (Program Counter)
- 13 PSR (Processor Status Register)
- 20 Instruction Decoder
- 22 Immediate Generation Machine Term
- 24 Offset Signal
- 30 Address Adder
- 32 Latch (Add\_LT)
- 40 ALU
- 44 PC Incrementer
- 45 Control Circuit Block
- 46 Four Bit Counters (Countx)
- 50 Memory (RAM)
- 52 Memory (ROM)
- 54 Register-Select Address Signal
- 60 Bus Control Unit (BCU)
- 72, 74, 76, 78 Internal bus
- 82, 84, 86, 88 Internal signal line
- 92, 94, 96, 98 External bus

## **CORRECTION OR AMENDMENT**

[Kind of official gazette] Printing of amendment by the convention of 2 of Article 17 of Patent Law

[Section partition] The 3rd partition of the 6th section

[Publication date] March 14, Heisei 15 (2003. 3.14)

[Publication No.] JP,10-91443,A

[Date of Publication] April 10, Heisei 10 (1998. 4.10)

[Annual volume number] Open patent official report 10-915

[Application number] Japanese Patent Application No. 9-135923

[The 7th edition of International Patent Classification]

G06F 9/42 330

9/30 350

9/46 313

[FI]

G06F 9/42 330 A

9/30 350 B

9/46 313 Z

## Machine English translation of JP 10-091443A

[Procedure revision]

[Filing Date] December 12, Heisei 14 (2002. 12.12)

[Procedure amendment 1]

[Document to be Amended] Specification

[Item(s) to be Amended] The name of invention

[Method of Amendment] Modification

[Proposed Amendment]

[Title of the Invention] An information processing circuit and a microcomputer

[Procedure amendment 2]

[Document to be Amended] Specification

[Item(s) to be Amended] Claim

[Method of Amendment] Modification

[Proposed Amendment]

[Claim(s)]

[Claim 1] The stack-pointer dedicated register only used for stack pointers,

A decode means to have the object code which makes this stack-pointer dedicated register an implied operand, to decode the object code of the instruction group only for stack pointers the processing based on this stack-pointer dedicated register was described to be, and to output a control signal based on this object code,

The information processing circuit characterized by including an activation means to perform said instruction group only for stack pointers based on the contents of said control signal and said stack-pointer dedicated register.

[Claim 2] In claim 1,

Said instruction group only for stack pointers includes the load instruction which has transfer register specific information in object code,

Said decode means

Said load instruction is decoded.

Said activation means

The information processing circuit characterized by performing either [ at least ] the data transfer from the first area to the first given register on memory, or the data transfer from said first given register to said first given area based on the register address specified by the memory address specified with said stack-pointer dedicated register, and said transfer register specific information in case said load instruction is executed.

[Claim 3] In either claim 1 - claim 2,

A stack-pointer migration instruction for said instruction group only for stack pointers to have migration information in object code, and move a stack pointer to it is included,

Said decode means

Said stack-pointer migration instruction is decoded,

Said activation means

The information processing circuit characterized by changing the contents of said stack-pointer dedicated register based on said migration information in case said stack-pointer migration instruction is executed.

[Claim 4] In either claim 1 - claim 3,

Two or more registers which were able to be continuously set in order are included, Said instruction group only for stack pointers includes either [ at least ] the continuation push instruction which has two or more register specific information in object code, or a continuation pop instruction,

Said decode means

Either [ at least ] said continuation push instruction or a continuation pop instruction is decoded, Said instruction-execution means

The information-processing circuit characterized by to attain to the memory address specified according to the contents of said stack-pointer dedicated register, and to perform at least one side of the processing which carries out multiple-times pop succeeding two or more of said registers from the processing which carries out a multiple-times push from two or more of said registers continuously to the stack prepared in memory, and said stack based on said two or more register specific information in case either [ at least ] said continuation push instruction or said continuation pop instruction is executed.

[Claim 5] In either claim 1 - claim 4,

The program counter register only for program counters is included,

Said instruction group only for stack pointers includes the branch instruction which is the instruction which branches to a subroutine, and a return instruction from said subroutine, Said decode means

Said branch instruction is decoded,

Said instruction-execution means

A means to perform at least one side of the return to shunting of the contents of said program counter register to the second given area of the stack prepared in memory, and the program counter register of the contents of said second area based on the memory address specified with said stack-pointer dedicated register in case said branch instruction is executed,

The information processing circuit characterized by including a means to update the contents of said stack-pointer dedicated register based on said shunting and said return.

[Claim 6] It is an information processing circuit containing the stack pointer assigned to two or more registers which were able to be continuously set in order, and one of general-purpose registers,

A means to decode the object code of one [ at least ] instruction of the continuation push instruction which has two or more register specific information in object code, and a continuation pop instruction, and to output a control signal based on this object code, The information-processing circuit characterized by to include a means perform at least one side of the processing which carries out multiple-times pop succeeding two or more of said registers from the processing which carries out a multiple-times push from two or more of said registers continuously to the stack prepared in memory, and said stack based on the memory address specified according to the contents of said control signal and said stack-pointer dedicated register, and said two or more register specific information in case either [ at least ] said continuation push instruction or said continuation pop instruction execute.

[Claim 7] In either claim 1 - claim 6,

The information processing circuit characterized by being a RISC method.

[Claim 8] In either claim 1 - claim 7,

The information processing circuit characterized by decoding a fixed-length instruction and performing executive operation based on this instruction.

[Claim 9] The microcomputer characterized by including a means to perform I/O with an information processing circuit, a storage means, and the exterior according to claim 1 to 8. [Procedure amendment 3]

[Document to be Amended] Specification

# Machine English translation of JP 10-091443A

[Item(s) to be Amended] 0001
[Method of Amendment] Modification
[Proposed Amendment]
[0001]
[Field of the Invention] This invention relates to the microcomputer which contains an information processing circuit and said information processing circuit.

(19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

## 特開平10-91443

(43)公開日 平成10年(1998) 4月10日

| (51) Int.Cl. <sup>8</sup> |      | 識別記号  | FI,     |      |         |
|---------------------------|------|-------|---------|------|---------|
| G06F                      | 9/42 | 3 3 0 | G 0 6 F | 9/42 | 3 3 0 A |
|                           | 9/30 | 3 5 0 | ·       | 9/30 | 3 5 0 B |
|                           | 9/46 | 3 1 3 |         | 9/46 | 3 1 3 Z |

|                        |                                  | 審査請求     | 未請求 請求項の数17 FD (全 29 頁)                    |  |  |
|------------------------|----------------------------------|----------|--------------------------------------------|--|--|
| (21)出願番号               | <b>特顏平9-135923</b>               | (71) 出願人 | 000002369<br>セイコーエプソン株式会社                  |  |  |
| (22)出願日                | 平成9年(1997)5月8日                   | (72)発明者  | 東京都新宿区西新宿2丁目4番1号<br>久保田 哲                  |  |  |
| (31)優先権主張番号<br>(32)優先日 | 特顏平8-127541<br>平 8 (1996) 5 月22日 |          | 長野県諏訪市大和3丁目3番5号 セイコーエブソン株式会社内              |  |  |
| (33) 優先権主張国            | 日本 (JP)                          | (72)発明者  | 工藤 真<br>長野県諏訪市大和3丁目3番5号 セイコ<br>ーエプソン株式会社内  |  |  |
|                        |                                  | (72)発明者  | 宮山 芳幸<br>長野県諏訪市大和3丁目3番5号 セイコ<br>ーエブソン株式会社内 |  |  |
|                        |                                  | (74)代理人  | 弁理士 井上 一 (外2名)<br>最終頁に続く                   |  |  |

#### 情報処理回路、マイクロコンピュータ及び電子機器 (54) 【発明の名称】

#### (57)【要約】

【課題】 スタックポインタを取り扱う処理を、短い命 令長で効率よく記述し、実行すること及びレジスタ退避 やレジスタ復旧の処理を、効率よく記述し、割り込み処 理及びサブルーチンコール・リターンの処理速度を向上 させること。

【解決手段】 CPU10は、スタックポインタ専用の レジスタSP14を含みSP14を暗黙のオペランドと するスタックポインタ専用命令群を命令デコーダ20で 解読する。そして、汎用レジスタ11、PC12、SP 14、アドレス加算器30、ALU40、PCインクリ メンタ44、内部バス72、74、76、78、内部信 号線82、84、86、88、外部パス92、94、9 6、98等を用いて前記スタックポインタ専用命令群を ハードウエア的に実行する。前記スタックボインタ専用 命令群は、SP相対ロード命令やスタックポインタ移動 命令やcall命令やret命令や連続プッシュ命令や 連続ポップ命令を含む。



#### 【特許請求の範囲】

【請求項1】 スタックポインタ専用に用いるスタック ポインタ専用レジスタと、

該スタックポインタ専用レジスタを暗黙のオペランドと するオブジェクトコードを有し、該スタックポインタ専 用レジスタに基づく処理が記述されたスタックポインタ 専用命令群のオブジェクトコードを解読して、該オブジ ェクトコードに基づき制御信号を出力する解読手段と、 前記スタックポインタ専用命令群を、前記制御信号及び 前記スタックボインタ専用レジスタの内容に基づき実行 10 する実行手段とを含むことを特徴とする情報処理回路。 【請求項2】 請求項1において、

前記スタックポインタ専用命令群が、転送レジスタ特定 情報をオブジェクトコードに有するロード命令を含み、 前記解読手段が、

前記ロード命令を解読し、

前記実行手段が、

前記ロード命令を実行する際、メモリ上の所与の第一の エリアから所与の第一のレジスタへのデータの転送及び 前記所与の第一のレジスタから前記所与の第一のエリア 20 へのデータの転送の少なくとも一方を、前記スタックポ インタ専用レジスタにより特定されるメモリアドレス及 び前記転送レジスタ特定情報により特定されるレジスタ アドレスに基づき行うことを特徴とする情報処理回路。 【請求項3】 請求項2において、

前記ロード命令が、前記メモリ上の前記第一のエリアの アドレスを特定するためのオフセットに関する情報であ るオフセット情報をオブジェクトコードに含み、

前記実行手段が、

前記スタックポインタ専用レジスタの内容と前記オフセ 30 ット情報により前記メモリアドレスを特定することを特 徴とする情報処理回路。

【請求項4】 請求項3において、

前記オフセット情報が、即値で与えられた即値オフセッ ト情報とメモリ上の所与のデータのサイズに関するデー タサイズ情報とを含み、

前記実行手段が、

前記即値オフセット情報と前記データサイズ情報とに基 づき、前記即値オフセット情報を左論理シフトしてオフ セット値を生成し、前記スタックポインタ専用レジスタ 40 の内容と前記オフセット値を加算した値により前記メモ リアドレスを特定するととを特徴とする情報処理回路。 【請求項5】 請求項1~請求項4のいずれかにおい

前記スタックポインタ専用命令群が、オブジェクトコー ドに移動情報を有しスタックボインタを移動するための スタックポインタ移動命令を含み、

前記解読手段が、

前記スタックポインタ移動命令を解読し、

前記実行手段が、

前記スタックボインタ移動命令を実行する際、前記移動 情報に基づき、前記スタックボインタ専用レジスタの内 容を変更することを特徴とする情報処理回路。

【請求項6】 請求項5において、

前記移動情報が、即値で与えられた即値移動情報を含

前記命令実行手段が、

前記即値移動情報と前記スタックポインタ専用レジスタ の内容とを加算する処理及び前記スタックボインタ専用 レジスタの内容から前記即値移動情報を減算する処理の 少なくとも一方の処理を行うことを特徴とする情報処理 回路。

【請求項7】 請求項1~請求項6のいずれかにおい て、

連続して順序づけられた複数のレジスタを含み、

前記スタックポインタ専用命令群が、複数レジスタ特定 情報をオブジェクトコードに有する連続プッシュ命令及 び連続ボップ命令の少なくとも一方を含み、

前記解読手段が、

前記連続プッシュ命令及び連続ポップ命令の少なくとも 一方を解読し、

前記命令実行手段が、

前記連続プッシュ命令及び前記連続ポップ命令の少なく とも一方を実行する際、前記複数のレジスタからメモリ に設けられたスタックへ連続して複数回ブッシュする処 理及び前記スタックから前記複数のレジスタに連続して 複数回ボップする処理の少なくとも一方を、前記スタッ クポインタ専用レジスタの内容により特定されるメモリ アドレスに及び前記複数レジスタ特定情報とに基づき行 うことを特徴とする情報処理回路。

【請求項8】 請求項7において、

0からn-1までのレジスタ番号で特定されたn個の汎 用レジスタを含み、

前記連続プッシュ命令及び連続ポップ命令の少なくとも 一方のオブジェクトコードが、前記複数レジスタ特定情 報として、前記レジスタ番号のいずれかが指定された最 終レジスタ番号を含み、

前記実行手段が、

レジスタ0から前記最終レジスタ番号で特定されるレジ スタまでの複数のレジスタからメモリに設けられたスタ ックへ連続して複数回プッシュする処理及び前記スタッ クから前記複数のレジスタに連続して複数回ボップする 処理の少なくとも一方を、前記スタックポインタ専用レ ジスタの内容により特定されるメモリアドレスに基づき 行うととを特徴とする情報処理回路。

【請求項9】 請求項7又は8のいずれかにおいて、 前記実行手段が、

前記複数のレジスタのいずれか所与のレジスタの内容 を、前記スタックボインタ専用レジスタで特定されるメ 50 モリアドレスに基づきメモリに設けられたスタックに書 き込む書き込み手段と、

前記書き込み手段による前記スタックへの書き込み回数 をカウントする書き込み回数カウント手段と、

· 前記カウント手段によってカウントされた前記書き込み 回数と前記複数レジスタ特定情報の値を比較する比較手 段とを含み、

前記書き込み手段が、

第一の入力と第二の入力を加算器で加算し書き込み先を 特定するための書き込みメモリアドレスを生成する書き 込みメモリアドレス生成手段と、

前記加算器の第一の入力が、連続専用命令の実行開始時にはスタックポインタ専用レジスタの内容となるように制御し、それ以降は書き込みアドレス生成手段によって生成された書き込みアドレスとなるよう制御する第一の入力制御手段と、

前記加算器の第二の入力に前記スタックから1ワードを 書き込んだときのオフセット値を出力する第二の入力制 御手段と、

前記複数レジスタ特定情報から前記書き込み回数を減じた値で特定されるレジスタの内容を、前記書き込みメモリアドレスに基づき前記スタックに書き込む手段とを含み.

前記比較手段の比較結果に基づき、複数のレジスタから の前記スタックへの書き込み及び書き込み終了を制御す ることを特徴とする情報処理回路。

【請求項10】 請求項7~9のいずれかにおいて、 前記命令実行手段が、

前記スタックボインタ専用レジスタで特定されるメモリアドレスに基づきメモリに設けられたスタックの内容を 読み出し、前記複数のレジスタのいずれか所与のレジス タに格納する読み出し手段と、

前記読み出し手段による前記スタックからの読み出し回 数をカウントする読み出し回数カウント手段と、

前記カウント手段によってカウントされた前記読み出し 回数と前記複数レジスタ特定情報の値を比較する比較手 段とを含み、

前記読み出し手段が、

第一の入力と第二の入力を加算器で加算し書き込み先を 特定するための書き込みメモリアドレスを生成する書き 込みメモリアドレス生成手段と、

前記加算器の第一の入力が、連続専用命令の実行開始時 にはスタックポインタ専用レジスタの内容となるように 制御し、それ以降は読み出しアドレス生成手段によって 生成された読み出しアドレスとなるよう制御する第一の 入力制御手段と、

前記加算器の第二の入力に前記スタックから1ワードを 書き込んだときのオフセット値を出力する第二の入力制 御手段と、

前記読み出しメモリアドレスに基づき前記スタックの内 容を読み出し、前記書き込み回数に基づき特定されるレ 50

ジスタに格納する読み出し手段とを含み、

前記比較手段の比較結果に基づき、前記スタックの内容 の読み出し及び読み出し終了を制御することを特徴とす る情報処理回路。

【請求項11】 請求項1~請求項10のいずれかにおいて、

プログラムカウンタ専用のプログラムカウンタレジスタ を含み、

前記スタックポインタ専用命令群が、サブルーチンへ分 岐する命令及び前記サブルーチンからのリターン命令で ある分岐命令を含み、

前記解読手段が、

前記分岐命令を解読し、

前記命令実行手段が、

前記分岐命令を実行する際、メモリに設けられたスタックの所与の第二のエリアへの前記プログラムカウンタレジスタの内容の待避及び前記第二のエリアの内容のプログラムカウンタレジスタへの復帰の少なくとも一方を、前記スタックポインタ専用レジスタにより特定されるメモリアドレスに基づき行う手段と、

前記待避及び前記復帰に基づき前記スタックポインタ専 用レジスタの内容を更新する手段とを含むことを特徴と する情報処理回路。

【請求項12】 連続して順序づけられた複数のレジスタと、いずれかの汎用レジスタに割り当てられたスタックボインタを含む情報処理回路であって、

複数レジスタ特定情報をオブジェクトコードに有する連続プッシュ命令及び連続ポップ命令の少なくとも一方の命令のオブジェクトコードを解読して、該オブジェクトコードに基づき制御信号を出力する手段と、

前記連続プッシュ命令及び前記連続ポップ命令の少なくとも一方を実行する際、前記複数のレジスタからメモリに設けられたスタックへ連続して複数回ブッシュする処理及び前記スタックから前記複数のレジスタに連続して複数回ポップする処理の少なくとも一方を、前記制御信号及び前記スタックポインタ専用レジスタの内容により特定されるメモリアドレス及び前記複数レジスタ特定情報とに基づき行う手段を含むことを特徴とする情報処理回路

0 【請求項13】 請求項1~請求項12のいずれかにおいて、RISC方式であることを特徴とする情報処理回路。

【請求項14】 請求項1~請求項13のいずれかにおいて

固定長の命令を解読し、該命令に基づき実行処理を行う ととを特徴とする情報処理回路。

【請求項15】 請求項1~請求項14のいずれかに記 載の情報処理回路と記憶手段と外部との入出力を行う手 段とを含むことを特徴とするマイクロコンピュータ。

【請求項16】 請求項15において、

前記スタックポインタに関連つけてオート変数の記憶領域が確保される構造を有する言語のプログラムが実行されるととを特徴とするマイクロコンピュータ。

【請求項17】 請求項15又は16のいずれかに記載されたマイクロコンピュータを含むことを特徴とする電子機器。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、情報処理回路、前という観点からは、固定長記情報処理回路を内蔵するマイクロコンピュータ、及び 10 くできることが好ましい。該マイクロコンピュータを用いて構成された電子機器に 【0010】また、例えば関する。 ンタに関連づけてオート系

#### [0002]

【背景技術及び発明が解決しようとする課題】従来、3 2ビットのデータを処理できるRISC方式のマイクロコンピュータでは、32ビット幅の固定長命令が用いられていた。その理由は、固定長命令を用いると、可変長命令を用いる場合に比べ、命令のデコードに要する時間を短縮でき、また、マイクロコンピュータの回路規模を小さくするととが出来るからである。

【0003】ところが、32ビットのマイクロコンビュータにおいても、特に32ビットも必要としない命令も多い。従って全ての命令を32ビットで記述すると、命令に冗長な部分が生じる命令が多くなり、メモリーの使用効率が悪くなる。

【0004】そとで、本願の発明者は、制御回路を複雑にすることなくメモリの使用効率を向上させるために、処理出来るデータのビット幅より短いビット幅の固定長命令を処理するマイクロコンピュータについての検討を行っていた。

【0005】しかし、例えば32ビット固定長の命令を 単に】6ビットの固定長にすると以下のような問題点が 生じる。

【0006】即ちRISC方式のマイクロコンピュータでは処理及び命令セットの汎用性を重視するため、スタックボインタを取り扱う処理を行う場合、いずれかの汎用レジスタをスタックボインタとして用い、汎用レジスタを操作対象とする命令を用いて前記処理を行っていた。従って、このような処理を記述する際の前記命令のには、スタックボインタとして使用している汎用レジス 40 タの指定が必要となる。

【0007】例えば、スタックポインタに所与のオフセット値を加えたメモリアドレスで特定されるデータを所与のレジスタに転送する処理を汎用レジスタを操作対象とする命令で記述する場合、その命令のオブジェクトコードには、前記オフセット値、前記所与のレジスタを特定する情報、スタックポインタとして使用しているレジスタを特定する情報が必要となる。

【0008】 このように、汎用レジスタを操作対象とす AXの場合である。レジスタEAX、る命令でスタックポインタを取り扱う処理を記述する場 50 EBXを全てスタックに書く場合は、

合、オブジェクトコードで指定する情報が多くなるため、命令の内容を16ビットの固定長で記述することが困難となる。ここで命令長を例えば32ビットにすると、命令の中にも特に命令に32ビットも必要としない命令も多いため、命令に冗長な部分を生じる命令が多くなり、メモリの使用効率の悪化を招く。

[0009]また、命令長が長くなればそれを格納するメモリも余分に必要になるため、メモリの効率的な使用という観点からは、固定長の命令に限らず、命令長を短くできるととが好ましい。

[00]0]また、例えばC言語のようにスタックボインタに関連づけてオート変数の記憶領域が確保される言語で記述されたプログラムを実行させる場合、スタックボインタを取り扱う命令が多くなるため、スタックボインタを取り扱う命令を効率的に記述し、実行させることが望ましい。

【0011】そとで、スタックポインタを取り扱う処理を行う場合、できるだけ短い命令長でその命令内容を記述し、実行することができるアーキテクチャが望まれて20 いた。

【0012】また最近の特にRISC方式のCPUは、性能を高めるため内部に多くの汎用レジスタを持つようになった。多くのレジスタを内部に持つことによりメモリにアクセスすることなくCPU内部で高速に多くの処理を出来るからである。このように内部レジスタを多く持つと、割り込み処理やサブルーチンコールの時のレジスタ退避と復旧の処理の際、退避すべきレジスタ数が多くなる。

【0013】以下、スタック系命令の中でもサブルーチンに入ったりでたりする際に多用するレジスタの待避、 復帰命令を例にとり従来例を説明する。

【0014】通常マイクロコンピュータの命令セットは CPUのレジスタをメモリに設けたスタックに待避した り復旧するための命令を持っている。そのための専用の 命令を持つもの、あるいはレジスタ間接アドレッシング 命令をもつものがある。

【0015】前記待避したり復旧したりするための命令 に関する技術としては、インテル社の80386に関して、「80386プログラミン」(John H. Crawford Patric P. Gelsigner 著 岩谷宏 訳)に以下のような記述がある。

【0016】即ちレジスタをスタックに書き込む命令として push、pusha、pushadがあり、スタックからレジスタにデータを戻すための命令としてpop、popa、popadがある。

【0017】push命令でレジスタをスタックに書き込むときは push EAX のようにオペランドとしてレジスタを指定する。これは32ビットレジスタEAXの場合である。レジスタEAX、ECX、EDX、ERXを全てスタックに乗く場合は

push EAX

push ECX

push EDX

push EBX

のようにpush命令を繰り返す。

【0018】 このようにpush、pop命令でレジスタを1本ずつ操作しているとオブジェクトコードのサイズは大きくなり、プログラムの実行ステップも多くなり、そのためプログラムの実行時間や処理動作はより遅くなる

7

【0019】そこで80386の有する8本の汎用レジスタ全てをスタックに書き込むにはpusha またはpushad 命令を使う。pushaは8本のレジスタの其々の下位16ビットレジスタを対象とし、pushadは32ビットを対象とする。pusha、pushadによりpush命令を8回繰り返すことを省略できる。

【0020】pop、popa、popad命令についても同様である。

【0021】push命令を繰り返すことの不利な点はプログラムコードが長くなること、1命令毎フェッチし実行するため実行が遅いことである。この点は、前記pusha、pushadにより、前記8本のレジスタを全てスタックに書き込む場合には大きく改善される。しかし、4本の場合とか6本の場合等のように8未満のレジスタを書き込む場合には、この点は改善されない。

【0022】即ち、80386のようにpusha、pushad、popa、popad命令で全てのレジスタを操作すると、レジスタの全てを退避・復旧する必要の無いときも、このサイクルの長い遅い命令を使わなければならない。このような場合、命令は一命令で済むがこの命令の実行サイクルは長くなるという問題が生じる。

【0023】また、call命令やリターン命令等でサブルーチンへ分岐したり、呼ばれたルーチンへ戻る際には、戻り先アドレスとして必要となるプログラムカウンタの待避や復旧の処理が必要となる。従来のRISC方式のCPUにおいては、これらの処理をソフトウエア的に実現していた。即ち、該処理を記述したアセンブラ命令(オブジェクトコード)を実行することにより、前記 40プログラムカウンタの待避や復旧の処理を行っていた。このため、call命令やリターン命令はオブジェクトコードの増加を招き、またl命令毎フェッチし実行するために実行速度の鈍化を招いていた。

【0024】本発明の目的は、スタックポインタを取り扱う処理を、短い命令長で効率よく記述し、実行するととができるアーキテクチャを有する情報処理回路、マイクロコンピュータ、電子機器を提供することである。

【0025】また 本発明の他の目的は、レジスタ退避 やレジスタ復旧の処理を、効率よく記述し、割り込み処 50

理及びサブルーチンコール・リターンの処理速度が速い 情報処理回路、マイクロコンピュータ、電子機器を提供 することである。

[0026]

【課題を解決するための手段】本発明は、スタックボインタ専用に用いるスタックボインタ専用レジスタと、該スタックボインタ専用レジスタと、該スタックボインタ専用レジスタを暗黙のオペランドとするオブジェクトコードを有し、該スタックボインタ専用レジスタに基づく処理が記述されたスタックボインタ専用の令群のオブジェクトコードを解読して、該オブジェクトコードに基づき制御信号を出力する解読手段と、前記スタックボインタ専用命令群を、前記制御信号及び前記スタックボインタ専用レジスタの内容に基づき実行する実行手段とを含むことを特徴とする。

【0027】とこにおいてオブジェクトコードとは、一般に翻訳プログラムによって機械語に翻訳した結果得られるプログラムコードのことをいうが、本発明においては、翻訳プログラムによるかいなかに関係なく、機械語で記述されているプログラムコードを含む広い概念で使20 用する。

【0028】本発明の情報処理回路は、スタックボインタ専用のスタックボインタ専用レジスタを有し、該スタックボインタ専用レジスタを操作対象とするスタックボインタ専用命令群の解読、実行を行うよう構成されている。

【0029】前記スタックボインタ専用命令群は、スタックボインタ専用レジスタを取り扱うための専用のオペコードを有しているため、オブジェクトコードのオペランドにスタックボインタを特定するための情報を必要としない。言い換えれば、前記スタックボインタ専用命令群はスタックボインタ専用レジスタを暗黙のオペランドとしている。このため、汎用レジスタの1つをスタックボインタに割あて、汎用レジスタを操作対象とする命令を用いてスタックボインタの操作を行う場合に比べて、短い命令長でスタックボインタを取り扱う命令を記述することができる。

[0030]従って本発明によれば、スタックポインタを取り扱う処理を短い命令長で記述し実行することができる情報処理回路を提供することができる。また、命令を記憶するメモリの使用効率のよい情報処理回路を提供するととができる。

【0031】本発明は、前記スタックポインタ専用命令群が、転送レジスタ特定情報をオブジェクトコードに有するロード命令を含み、前記解読手段が、前記ロード命令を解読し、前記実行手段が、前記ロード命令を実行する際、メモリ上の所与の第一のエリアから所与の第一のレジスタへのデータの転送及び前記所与の第一のレジスタから前記所与の第一のエリアへのデータの転送の少なくとも一方を、前記スタックボインタ専用レジスタ特定り特定されるメモリアドレス及び前記転送レジスタ特定

情報により特定されるレジスタアドレスに基づき行うと とを特徴とする。

【0032】 とこにおいて前記スタックボインタ専用命 会群に含まれる前記ロード命令とは、メモリとレジスタ 間でデータの転送を行う命令であり、メモリからレジスタへの転送及びレジスタからメモリへの転送の少なくとも一方を含む概念である。なお、データの内容は問わず アドレスデータも含む概念である。メモリアドレスとは、転送の際のメモリ上のエリアを特定するためのアドレスをいう。

【0033】前記ロード命令は、スタックボインタ専用レジスタを操作対象とするための専用のオペコードを有しているため、オブジェクトコードのオペランドにスタックボインタを特定するための情報を必要としない。このため、スタックボインタに関連づけたメモリアドレスを有するメモリ上のエリアとレジスタ間でデータの転送処理を行わせる場合、短い命令長で記述することができる。

【0034】本発明は、前記ロード命令が、前記メモリ上の前記第一のエリアのアドレスを特定するためのオフセットに関する情報であるオフセット情報をオブジェクトコードに含み、前記実行手段が、前記スタックボインタ専用レジスタの内容と前記オフセット情報により前記メモリアドレスを特定することを特徴とする。

【0035】ととにおいてオフセット情報とは、オフセット値を直接即値で指定したものでもよいし、オフセット値が格納されたレジスタ等のアドレスを指定する場合のように間接的に指定する場合でもよい。オフセット情報を含んだ前記ロード命令が実行される場合、転送の際に必要となる前記メモリアドレスは、スタックポインタ専用レジスタの内容及びオフセット情報に基づき特定される。

[0036]従ってスタックポインタ及び前記オフセット情報に基づき特定されるメモリアドレスを有するメモリ上のエリアとレジスタ間でデータの転送処理を行わせる場合、短い命令長で記述することができる。

[0037] また本発明によれば、例えばスタックポインタが常にワード境界をさすような構造の情報処理回路においても、適当なオフセット情報を指定することにより、スタック上の任意のエリアを指定することが可能となる。このため、データのサイズに応じて効率良くスタックに格納することができ、スタックの使用効率の向上を図ることができる。

【0038】本発明は、前記オフセット情報が、即値で与えられた即値オフセット情報とメモリ上の所与のデータのサイズに関するデータサイズ情報とを含み、前記実行手段が、前記即値オフセット情報と前記データサイズ情報とに基づき、前記即値オフセット情報を左論理シフトしてオフセット値を生成し、前記スタックボインタ専用レジスタの内容と前記オフセット値を加算した値によ 50

り前記メモリアドレスを特定することを特徴とする。 【0039】ことにおいて即値オフセット情報とは、オ フセット値を直接即値で指定したものをいう。またデー タサイズ情報とは、転送すべきメモリ上データのサイズ をいう。通常データサイズは、8ビットのバイトデータ や、16ビットのハーフワードデータ、32ビットのワ ードデータ等の2°(nは3以上)で表される。メモリ 上のアドレスはバイト単位に与えられており、ハーフワ ードデータはハーフワード境界におかれ、ワードデータ 10 はワード境界におかれる。従って、ハーフワードデータ のメモリアドレスの下位の1ビットは0となり、ワード データのメモリアドレスの下位の2ビットは00とな る。スタックポインタのアドレスは、ワード境界を指し ているため、ハーフワードデータのメモリアドレスを生 成する場合のオフセット値の下位の1ビットは0とな り、ワードデータのメモリアドレスを生成する場合のオ フセット値の下位の2ビットは00となる。

【0040】また、左論理シフトとは、データのビット列を左にずらし、シフトによってデータの右側にでるあ 20 きビット(シフトインビット)に0が入るシフトをい う。

【0041】本発明によれば、データサイズに基づき、前記オフセット即値情報の左論理シフトを行うため、データサイズによって一義的に決まる下位のピットを省略して、即値オフセット情報を記述することができる。従って、即値オフセット情報を効率的に指定することができ、バイト以外のデータサイズの場合、そのまま指定する場合に比べて、より大きいオフセット値に指定が可能となる。

【0042】また該命令を用いることによって、データのメモリへの書き込み、読み出し時にそのデータサイズに応じた適切な境界位置が選択されることになる。

[0043]本発明は、前記スタックポインタ専用命令 群が、オブジェクトコードに移動情報を有しスタックポ インタを移動するためのスタックポインタ移動命令を含 み、前記解読手段が、前記スタックポインタ移動命令を 解読し、前記実行手段が、前記スタックポインタ移動命 令を実行する際、前記移動情報に基づき、前記スタック ポインタ専用レジスタの内容を変更することを特徴とす 40 る。

【0044】前記スタックポインタ移動命令は、スタックポインタ専用レジスタを操作対象とするための専用のオペコードを有しているため、オブジェクトコードのオペランドにスタックポインタを特定するための情報を必要としない。このため、スタックを移動させたい場合、短い命令長で記述することができる。従って、スタックに格納されているデータの処理やスタックポインタに関連づけて記憶されているデータの処理を行う際の命令の記述量を削減することができる。

【0045】本発明によればスタックの移動が容易に行

えるため、特に異なるルーチンにおいてそれぞれ異なるスタックエリアを確保して処理を行う場合に有効である。即ちルーチンごとにスタックボインタを移動させる処理を行うととで、広範囲な領域にわたるアドレス指定が可能となる。

[0046] 本発明は、前記移動情報が、即値で与えられた即値移動情報を含み、前記命令実行手段が、前記即値移動情報と前記スタックポインタ専用レジスタの内容とを加算する処理及び前記スタックポインタ専用レジスタの内容から前記即値移動情報を減算する処理の少なくとも一方の処理を行うことを特徴とする。

【0047】本発明によれば、スタックポインタの値を 即値移動情報で指定された分だけ上方又は下方に移動さ せる処理を短い命令長で記述することができる。

[0048] 本発明は、連続して順序づけられた複数のレジスタを含み、前記スタックボインタ専用命令群が、複数レジスタ特定情報をオブジェクトコードに有する連続プッシュ命令及び連続ボップ命令の少なくとも一方を含み、前記解読手段が、前記連続プッシュ命令及び連続ポップ命令の少なくとも一方を解読し、前記命令実行手段が、前記連続プッシュ命令及び前記連続ボップ命令の少なくとも一方を実行する際、前記複数のレジスタからメモリに設けられたスタックへ前記複数のレジスタからメモリに設けられたスタックへ前記複数のレジスタが高記な数のレジスタが高記な数回ボップする処理の少なくとも一方を、前記スタックボインタ専用レジスタの内容により特定されるメモリアドレスに及び前記複数レジスタ特定情報とに基づき行うととを特徴とする。

【0049】ブッシュとはメモリに設けられたスタックにデータを積み重ねて格納すること、ボップとは前記スタックからデータを取り出すことをいう。ここにおいてブッシュする処理及びボップする処理とは、前記格納及び取り出しの処理と、それに伴うスタックボインタの更新処理の路は1のレジスタからスタックにデータやアドレスを格納するためのpush命令、スタックの内容をレジスタに取り出すpop命令を有している。該push命令やpop命令は、レジスタンクとのデータのやり取りや、該やり取りに伴うスタックポインタの更新を行う。

【0050】従って複数のレジスタとスタックでデータ 等のやり取りを行う場合には、これらの命令を複数回実 行することが必要となる。

【0051】しかし本発明によれば、前記連続プッシュ命令や前記連続ポップ命令を実行すると、push命令を連続して複数回実行する場合やpop命令を連続して複数回実行する場合と同じ効果が得られる。即ち複数のレジスタとスタックとの間のデータのやり取り及び該やり取りに伴うスタックボインタの更新を1命令で実行することが出来る。このため複数のレジスタとスタックとの間のデータの転送を行う場合、push命令あるいは50

12

рор命令をくり返すことによりオブジェクトコードサ イズが増大するのを防ぐことができる。またプログラム 実行ステップが長くなることを回避し、無駄なサイクル を消費することなく、割り込み処理及びサブルーチンコ ール・リターンの処理速度の向上を図ることができる。 【0052】本発明は、0からnーlまでのレジスタ番 号で特定されたn個の汎用レジスタを含み、前記連続プ ッシュ命令及び連続ポップ命令の少なくとも一方のオブ ジェクトコードが、前記複数レジスタ特定情報として、 前記レジスタ番号のいずれかが指定された最終レジスタ 番号を含み、前記実行手段が、レジスタ0から前記最終 レジスタ番号で特定されるレジスタまでの複数のレジス タからメモリに設けられたスタックへ連続して複数回プ ッシュする処理及び前記スタックから前記複数のレジス タに連続して複数回ボップする処理の少なくとも一方 を、前記スタックポインタ専用レジスタの内容により特 定されるメモリアドレスに基づき行うことを特徴とす る。

【0053】通常汎用レジスタが複数ある場合、レジスタを特定するためのアドレスを有している。本発明では0からn-1までの連続したレジスタ番号で前記レジスタを特定している。

[0054] 本発明によれば、前記最終レジスタ番号に任意のレジスタ番号を指定することにより、レジスタ0から前記最終レジスタ番号までの連続した複数のレジスタとメモリとの間でデータをブッシュする処理及びボップする処理の少なくとも一方が行われる。従って、レジスタ番号0のレジスタから順番にレジスタを使用するような構造を有するプログラムの実行において、レジスタの待避や復旧を効率的に行うことができる。

【0055】本発明は、前記実行手段が、前記複数のレ ジスタのいずれか所与のレジスタの内容を、前記スタッ クポインタ専用レジスタで特定されるメモリアドレスに 基づきメモリに設けられたスタックに書き込む書き込み 手段と、前記書き込み手段による前記スタックへの書き 込み回数をカウントする書き込み回数カウント手段と、 前記カウント手段によってカウントされた前記書き込み 回数と前記複数レジスタ特定情報の値を比較する比較手 段とを含み、前記書き込み手段が、第一の入力と第二の 入力を加算器で加算し書き込み先を特定するための書き 込みメモリアドレスを生成する書き込みメモリアドレス 生成手段と、前記加算器の第一の入力が、連続専用命令 の実行開始時にはスタックボインタ専用レジスタの内容 となるように制御し、それ以降は書き込みアドレス生成 手段によって生成された書き込みアドレスとなるよう制 御する第一の入力制御手段と、前記加算器の第二の入力 に前記スタックから 1 ワードを書き込んだときのオフセ ット値を出力する第二の入力制御手段と、前記複数レジ スタ特定情報から前記書き込み回数を減じた値で特定さ れるレジスタの内容を、前記書き込みメモリアドレスに

等をコールする命令、割り込み処理及び例外処理及びデ バッグ処理ルーチン等へ分岐するためのソフトウェア割 り込み命令、ソフトウェアデバッグ割り込み命令等も含 む。またサブルーチンからのリターン命令には、割り込

み処理及び例外処理及びデバッグ処理ルーチン等からの リターン命令を含む。

14

【0060】通常サブルーチンへ分岐する場合や前記サ ブルーチンから戻る場合プログラムカウンタの待避や復 帰が必要となる。

【0061】本発明では、前記サブルーチンへ分岐する 命令の実行及びサブルーチンからリターンする命令を実 行する際に前記プログラムカウンタの待避及び復帰も同 時に行う。即ち、本発明の情報処理回路は、サブルーチ ンへ分岐する命令及び前記サブルーチンからのリターン 命令のいずれか―命令でプログラムカウンタの待避及び 復帰が出来る回路構成を有している。とのためサブルー チンへの分岐やサブルーチンからのリターンに伴って必 要となる前記プログラムカウンタの待避及び復帰の命令 が不要となり、命令数を削減することができる。また、

無駄なサイクルを消費することなく、サブルーチンコー ル・リターン等の他のルーチンへ分岐時の処理速度の向 上を図るととができる。

【0062】また、ソフトウエア割り込み命令が発生し た場合には、例えばCPU等の情報処理回路の現在の状 態を保持するプロセッサーステータスレジスタの待避及 び復帰も必要となる。従って、ソフトウエア割り込み命 令等の場合は該命令の実行時にプロセッサーステータス レジスタの待避及び復帰も同時に行うようにするととが 好ましい。

【0063】本発明は、連続して順序づけられた複数の レジスタと、いずれかの汎用レジスタに割り当てられた スタックポインタを含む情報処理回路であって、複数レ ジスタ特定情報をオブジェクトコードに有する連続プッ シュ命令及び連続ポップ命令の少なくとも一方の命令の オブジェクトコードを解読して、該オブジェクトコード に基づき制御信号を出力する手段と、前記連続プッシュ 命令及び前記連続ボップ命令の少なくとも一方を実行す る際、前記複数のレジスタからメモリに設けられたスタ ックへ連続して複数回プッシュする処理及び前記スタッ クから前記複数のレジスタに連続して複数回ボップする 処理の少なくとも一方を、前記制御信号及び前記スタッ クボインタ専用レジスタの内容により特定されるメモリ アドレス及び前記複数レジスタ特定情報とに基づき行う 手段を含むことを特徴とする。

【0064】本発明は、汎用レジスタをスタックポイン タとして使用する場合の前記連続フッシュ命令及び前記 連続ボップ命令に関する。

【0065】本発明によれば、前記連続プッシュ命令や 前記連続ボップ命令を実行すると、push命令を連続 従ってサブルーチンへ分岐する命令とは、サブルーチン 50 して複数回実行する場合やpop命令を連続して複数回

基づき前記スタックに書き込む手段とを含み、前記比較 手段の比較結果に基づき、複数のレジスタからの前記ス タックへの書き込み及び書き込み終了を制御することを 特徴とする。

【0056】また本発明は、前記命令実行手段が、前記 スタックポインタ専用レジスタで特定されるメモリアド レスに基づきメモリに設けられたスタックの内容を読み 出し、前記複数のレジスタのいずれか所与のレジスタに 格納する読み出し手段と、前記読み出し手段による前記 スタックからの読み出し回数をカウントする読み出し回 10 数カウント手段と、前記カウント手段によってカウント された前記読み出し回数と前記複数レジスタ特定情報の 値を比較する比較手段とを含み、前記読み出し手段が、 第一の入力と第二の入力を加算器で加算し書き込み先を 特定するための書き込みメモリアドレスを生成する書き 込みメモリアドレス生成手段と、前記加算器の第一の入 力が、連続専用命令の実行開始時にはスタックポインタ 専用レジスタの内容となるように制御し、それ以降は読 み出しアドレス生成手段によって生成された読み出しア ドレスとなるよう制御する第一の入力制御手段と、前記 20 加算器の第二の入力に前記スタックから1ワードを書き 込んだときのオフセット値を出力する第二の入力制御手 段と、前記読み出しメモリアドレスに基づき前記スタッ クの内容を読み出し、前記書き込み回数に基づき特定さ れるレジスタに格納する読み出し手段とを含み、前記比 較手段の比較結果に基づき、前記スタックの内容の読み 出し及び読み出し終了を制御することを特徴とする。

【0057】とのようにすると連続した値で順序づけて 特定される複数のレジスタのスタックへの待避又はスタ ックから連続した値で特定される複数のレジスタへの復 30 旧をカウント手段と簡単なシーケンス制御のみで実現可 能である。従って少ないゲート数の情報処理回路で実現 出来るため、ワンチップのマイクロコンピュータ等に適 したものである。

【0058】本発明は、プログラムカウンタ専用のプロ グラムカウンタレジスタを含み、前記スタックポインタ 専用命令群が、サブルーチンへ分岐する命令及び前記サ プルーチンからのリターン命令である分岐命令を含み、 前記解読手段が、前記分岐命令を解読し、前記命令実行 手段が、前記分岐命令を実行する際、メモリに設けられ 40 たスタックの所与の第二のエリアへの前記プログラムカ ウンタレジスタの内容の待避及び前記第二のエリアの内 容のプログラムカウンタレジスタへの復帰の少なくとも 一方を、前記スタックポインタ専用レジスタにより特定 されるメモリアドレスに基づき行う手段と、前記待避及 び前記復帰に基づき前記スタックポインタ専用レジスタ の内容を更新する手段とを含むことを特徴とする。

【0059】ここにおいてサブルーチンとは、割り込み 処理及び例外処理及びデバッグ処理ルーチン等も含む。

実行する場合と同じ効果が得られる。即ち複数のレジスタとスタックとの間のデータのやり取り及び該やり取りに伴うスタックボインタの更新を1命令で実行することが出来る。このため複数のレジスタとスタックとの間のデータの転送を行う場合、push命令あるいはpop命令をくり返すことによりオブジェクトコードサイズが増大するのを防ぐことができる。またプログラム実行ステップが長くなることを回避し、無駄なサイクルを消費することなく、割り込み処理及びサブルーチンコール・リターンの処理速度の向上を図ることができる。

[0066]本発明はの情報処理回路はRISC方式であるととを特徴とする。

【0067】RISC方式の情報処理回路は、ハードウエアを小型化して高速化を図ることを目的として設計されている。このため汎用レジスタを多く有しており、命令セットを汎用性の高いものに絞ることで命令数の削減を図っている。

【0068】従ってRISC方式の情報処理回路では、スタックボインタを汎用レジスタに割り当て、スタックボインタを扱う場合は汎用レジスタを扱う命令セットを 20 用いて処理を行っていた。しかしとの様な方法では命令長が大きくなりメモリの使用効率がよくない。

【0069】本発明によれば、RISC方式の情報処理 回路において、命令長を削減することが出来、メモリの 使用効率を上げることが出来る。

【0070】本発明の情報処理回路は、固定長の命令を解読し、該命令に基づき実行処理を行うととを特徴とする。

【0071】固定長命令を用いると可変長命令を用いる場合に比べ、命令のデコードに要する時間を短縮でき、情報処理回路の回路規模を小さくすることが出来る。固定長命令を採用する場合、命令に冗長な部分が出来るのを防ぎメモリを効率よく使用するためには、各命令に必要なビット数はばらつきが少なく、出来るだけ短いほうが好ましい。

【0072】本発明によれば、一般に命令長が長くなりがちなスタックポインタを取り扱う命令の命令長を短くすることができる。従って固定長命令を採用した場合であっても命令に冗長な部分が出来るのを防ぎ、メモリを効率よく使用することが出来る。

【0073】本発明のマイクロコンピュータは、前述した本発明の情報処理回路と記憶手段と外部との入出力を行う手段とを含むことを特徴とする。

【0074】本発明によれば、処理速度が速くメモリの使用効率のよい、マイクロコンピュータを提供することが出来る。

【0075】本発明のマイクロコンピュータは、前記スタックボインタに関連づけてオート変数の記憶領域が確保される構造を有する言語のプログラムが実行されるととを特徴とする。

【0076】スタックボインタに関連づけてオート変数の記憶領域が確保される構造を有するする言語として、例えばC言語がある。この様な言語のプログラムの処理を本発明のマイクロコンピュータが行う場合、処理速度及びメモリの使用効率を効果的に向上させることが出来る。

16

[0077]本発明の電子機器は、前述した本発明のマイクロコンピュータを含むことを特徴とする。

[0078] 本発明によれば、処理速度が速くメモリの 使用効率のよい情報処理回路を内蔵しているため、安価 で高機能な電子機器を提供することが出来る。

[0079]

[発明の実施の形態]以下、本実施例を図面に基づき説明する。

[0080] (実施例1)

#### (1) 本実施例のCPUの構成

本実施例のCPUはパイプラインとロード・ストア型のアーキテクチュアによって、ほとんど全ての命令を1サイクルで実行する。全ての命令は16ビットの固定長で記述されており、本実施例のCPUの処理する命令は極めて小さいオブジェクトコードサイズを実現している。【0081】特に本実施例のCPUは、スタックボインタを取り扱う処理を効率よく記述し実行するためにスタックポインタ専用のレジスタを有し、該スタックポインタ専用レジスタを暗黙のオペランドとするオブジェクトコードを有するスタックポインタ専用命令群の命令セットを解読、実行出来るよう構成されている。

【0082】図1は、本実施例のCPUの回路構成の概略を説明するための図である。

【0083】本CPU10は、汎用レジスタ11、プログラムカウンタが格納されているPC12、プロセッサーステータスレジスタ(PSR)13、スタックポインタ専用のレジスタであるSP14を含むレジスタセットと、命令デコーダ20、即値生成器22、アドレス加算器30、ALU40、PCインクリメンタ44及び各種内部バス72、74、76、78、各種内部信号線82、84、86、88等を含む。

【0084】前記命令デコーダ20は、入力したオブジェクトコードを解読し、該命令を実行するために必要なの処理を行い、必要な制御信号を出力する。なお、該命令デコーダ20は前記スタックボインタ専用命令のオブジェクトコードを解読して該命令に基づき制御信号を出力する前記解読手段としても機能する。

【0085】即値生成器22は、オブジェクトコードに含まれた即値に基づき、実行時に使用する32ビットの即値データを生成したり、各命令の実行に必要な0、±1、±2、±4のconstantデータを生成したりする。PCインクリメンタ44は、命令の実行サイクルに基づきPC12に格納されたプログラムカウンタの更新を行

50 う。アドレス加算器30は、各種レジスタに格納されて

いる情報や即値生成器22で生成される即値データの加 算を行いメモリからデータを読み出す際に必要なアドレ スデータを生成する。ALU40は数値演算や論理演算 を行う。

【0086】また、該CPUは内部に各種バスや信号線 を含んでいる。PA\_BUS72やPB\_BUS74は ALU40の入力信号を伝送する機能等を有する。WW ■BUS76はALU40の演算結果を取り出して汎用 レジスタに伝送する機能等を有する。XA\_BUS78 は汎用レジスタ11やSP14から取り出したアドレス 10 データを伝送する機能等を有する。1 A信号線82は、 CPU内部の各部から外部のI\_ADDR\_BUS92 ヘアドレスデータを伝送する。DA信号線84は、CP U内部の各部から外部のD\_ADDR\_BUS96へア ドレスデータを伝送する。DIN信号線86は、CPU 外部のD\_DATA\_BUS98からCPU内部の各部 ヘデータを伝送する。DOUT信号線88は、CPU内 部の各部から外部のD\_DATA\_BUS98ヘデータ を伝送する。IA入力切換83はIA信号線82へ出力 される各種信号 (PA\_BUS72、WW\_BUS7 6. PC 1 2、PC + 2) の切換を行う。 DOUT入力 切換89はDOUT信号線88へ出力される各種信号 (PA\_BUS72, WW\_BUS76, PC12, P C+2) の切換を行う。

【0087】また、CPU10の前記各部は前記命令デ コーダ20の出力する制御信号に基づき、命令の実行を おとなうもので、スタックポインタ専用命令群を、前記 制御信号及び前記スタックポインタ専用レジスタの内容 に基づき実行する前記実行手段としても機能する。

【0088】本CPU10は、16ビットの命令データ バス (1\_DATA\_BUS) 94、命令データアクセ スのための命令アドレスバス(I\_ADDR\_BUS) 92と、32ビットのデータバス(D\_DATA\_BU S) 98と、データアクセスのためのデータアドレスバ ス (D\_ADDR\_BUS) 96と、コントロール信号 のための図示しないコントロールバスを介して外部と信 号のやり取りを行う。

【0089】(2) 本実施例のCPU有するレジスタセ

ついて、必要な部分について説明する。

【0090】図2に本実施例のCPUの持つレジスタセ ットを示す。本実施例のCPUは、汎用レジスタ11を 16本と、PC12、PSR13、SP14、図示しな いALR (算術演算ローレジスタ) 15、図示しないA HR (算術演算ハイレジスタ) 16を含むレジスタセッ トを有している。

【0091】前記汎用レジスタ11は機能的に等価な3 2ピットのレジスタであり、R O からR 1 5 と名付けら ている。該汎用レジスタ11はデータ演算時及びアドレ 50 PSRを退避する。

ス計算時に使用される。

【0092】またPC12は、32ビット長のインクリ メンタルカウンタであり、現在実行中の命令のアドレス であるプログラムカウンタを保持している。本文中で、 レジスタ名を指すときはPCといい、PCに格納された 値をさすときはプログラムカウンタという。

18

【0093】該PC12は、ロード命令等で直接アクセ スするととは出来ない。call命令、int命令や割 り込み、例外が発生すると、プログラムカウンタはPC 12から読み出されスタックに退避される。 この様に分 岐命令が実行されると飛びさきアドレスがPCに設定さ れる。条件分岐命令で分岐する場合も同様である。そし て、ret命令やreti命令により、戻りさき命令ア ドレスがスタックより読み出され、PC12に復帰され

【0094】PSR (プロセッサステータスレジスタ) 13は、フラグが割り当てられている32ビットレジス タであり、CPUの現在の状態を保持している。int 命令、割り込み、例外等が発生すると、それぞれの処理 20 ルーチンに分岐する際に、その時のPSRの状態がスタ ックに退避される。逆にreti命令の実行で、退避さ れていた値がPSRに復帰される。

【0095】SP14は32ビットのスタックポインタ 専用のレジスタで、スタックの先頭番地をさすスタック ボインタが格納されている。本文中で、レジスタ名を指 すときはSPといい、SPに格納された値をさすときは スタックポインタという。但し、スタックポインタは常 にワードの境界を指しているため、前記スタックポイン タの下位の2ピットは常に0である。

【0096】該スタックポインタは、本実施例で用意し ているスタックポインタ専用命令群に含まれる各種命令 の実行や、トラップの発生に伴い更新される。スタック ポインタの更新を行うスタックポインタ専用命令として は、call命令やret命令等の他のルーチンへ分岐 する命令、スタックポインタ移動命令、pushn命 令、popn命令等がある。例えばcall命令が実行 されると、まずスタックポインタがワードサイズ(4) だけデクリメント (-4) され、PC12がスタックに 退避される。また、ret命令が実行されると、逆にス 次に本実施例のCPUが有するレジスタセットの概要に 40 タックより戻りさきアドレスがPCにロードされ、スタ ックポインタはワードサイズ分インクリメント(+4) される。int命令が実行されたり、または、割り込 み、例外等が発生したときには、スタックにPCやPS Rの値が以下の手順で退避される。

[0097]1)SP=SP-4

2) スタックポインタで指されるスタックの先頭番地に PCを退避する。

[0098]3)SP=SP-4

4) スタックポインタで指されるスタックの先頭番地に

\* 定する。

省略する。

[0104]

【〇 】 〇 】 】 トラップ処理から元のルーチンに復帰する

と、CPUはスタックからPSR、PCの順に読み出し

て、PSRを元の値に戻すとともに、戻りアドレスに分

岐する。なお、例外にはデバッグ例外、アドレス不整列

【0102】ALR (算術演算ローレジスタ) 15及び

AHR(算術演算ハイレジスタ)16については説明を

【0103】CPUの持つ特殊レジスタPSR13、S

P14、ALR15、AHR16はロード命令を使って

汎用レジスタとの間でデータ転送を行うことが出来る。

各レジスタは、特殊レジスタ番号を持っており、との番

例外、オーバーフロー例外、ゼロ除算例外等がある。

には、reti命令を使う。reti命令を実行する

【0099】reti命令が実行されると、上記とは逆 の処理を行ってCPUは以前の状態に戻る。とのように call命令やret命令やint命令が実行される と、該実行に基づきスタックポインタが更新される。各 命令の詳細については後述する。

19

【0100】また、本実施例においてトラップとは、命 令の実行に非同期に発生する割り込みと命令の実行によ り発生する例外を合わせたものをいう。トラップが発生 すると、CPUはプログラムカウンタ(PC)とプロセ ッサステータスレジスタ (PSR) をスタックに退避し 10 てからトラップテーブルよりベクタテーブルを読み出 し、そのトラップに対応する処理ルーチンへ分岐する。 トラップの発生に伴って、PSR中の1Eピット(割り 込みイネーブル) はクリアされ、それ以上のマスク可能 割り込みの発生が禁止される。再び、マスク可能な外部 割り込みをイネーブルにするには,PSRに対するロー ド命令を使ってPSRのIEビットに1を書き込んで設\*

特殊レジスタ番号 特殊レジスタ名 %PSR プロセッサステータスレジスタ 0 %SP 1 SP 2

算術演算ローレジスタ 3 算術演算ハイレジスタ

(3) スタック及びスタックポインタについての説明 スタックはメモリにもうけられた一時記憶領域で、連続 した領域の下方からデータが棚状に積み重ねて記憶され る。スタックボインタは、スタックメモリの一番上つま り最後に記憶されたデータのアドレスを示している。 【0105】スタックボインタの一般的な動作について

図3を用いて説明する。

【0106】図3の100はメモリに設けられたスタッ ク領域を表している。斜線部分102が最後に格納され たデータであるとすると、SP14に格納されたスタッ クポインタは、該データのメモリアドレス1000を示 している。なお、斜線部分102の下方領域104は既 にデータが格納されている領域で、斜線部分102の上 方領域106はこれからデータが格納される領域を示し ている。

【0107】スタックポインタは常にワードの境界を指 しているため、スタックに情報を書き込む時はSP14 の格納されたスタックポインタを4だけ上に動かして、 該スタックポインタのさす場所に情報を格納する。また スタックに格納されている情報を取り出すときは、現在 SP14が示すアドレスの情報をとりだして、SP14 に格納されたスタックポインタを4だけ下に動かす。と のようにスタックポインタは常に最後にスタックに格納 された情報の格納アドレスを示している。

【0108】(4)スタックポインタ専用命令群につい ての説明

通常RISC方式のCPUでは汎用レジスタをスタック ボインタとして使用するが、本実施例ではスタックボイ 50 作成したオブジェクトコードで記述されたプログラムで

アセンブラの記述方法

号を使ってアクセスされる。

%ALR %AHR

ンタ専用のレジスタであるSP14を有しており、前記 スタックポインタ専用命令群の操作対象となる。

【0109】前記スタックポインタ専用命令群は、スタ ックポインタ専用のレジスタであるSP14を暗黙のオ ペランドとし、SP14をもちいて操作をおこなう複数 の命令の総称である。該スタックポインタ専用命令群 は、SP相対ロード命令(1d等)、スタックポインタ 30 移動命令(add、sub)、サブルーチンへ分岐する 命令 ( c a ] ] 等) 及びリターン命令 ( r e t 等) 等の 他のルーチンへ分岐する命令、連続プッシュ命令(pu shn)、連続ポップ命令(popn)を含む。

【0110】とれらにの命令に共通するのは、スタック ボインタ専用命令であるため、オブジェクトコードにス タックポインタを特定するための情報が必要ないという ことである。従ってスタックポインタを用いる処理を短 い命令長で効率よく記述することができるという効果も 共通する。

【0]]])また、これらの命令を用いるとメモリに設 けられたスタックに記憶されている情報の処理を効率よ く行うととができる。また、割り込み処理及びサブルー チンコール・リターンの処理を効率よく行うことが出来

【0112】ととで、サブルーチンがコールされる場合 の前記スタックポインタ専用命令の使用例とメモリにも うけられたスタックの使用状態及びスタックポインタの 状態について図4を用いて説明する。図4のメインプロ グラム500とサブルーチン520は、Cコンパイラが

21

ある。540はメモリ上のスタックの状態を示してい る。502は汎用レジスタR0~R3を使用する処理が 行われていることを示している。506はサブルーチン コール命令を示している。メインプログラム500でサ ブルーチンコール命令が実行されるサブルーチンコール 命令前、即ち504に示す前の命令が実行された後スタ ックポインタ(SP)はメモリ上のスタック540上の ①のアドレスを指していたとする。前記サブルーチンコ ール命令が実行されると、実行の制御はサブルーチン5 20 にわたる。このとき本実施例では、前記スタックボ 10 インタ専用命令であるサブルーチンへ分岐する命令(c all命令)が実行される。該命令が実行されると、ス タックボインタ (SP) の値は自動的に-4だけインク リメントされ(図4のOSP参照)、該スタックポイン タのSPが指しているスタック上のエリア544にメイ ンプログラムへのリターンアドレスが格納される。

【0113】そして、サブルーチン520側では、実行の最初にメインプログラムで使用されていた汎用レジスタR0~R3に格納されていた値をスタックに転送する処理を行う。524は、汎用レジスタR0~R3に格納されていた値をスタックに待避する処理を行うスタックボインタ専用命令である連続プッシュ命令(pushn)を示している。該命令が実行されると汎用レジスタR0~R3に格納されていた値が連続的にスタックに転送され、図4の550に示すように、スタック540に格納される。この処理の実行が終わる(524 $\mathfrak G$ )と、スタックボインタ(SP)は546を指している( $\mathfrak G$ SP)。

【0114】次にサブルーチン520では、サブルーチンで使用するオート変数領域の確保を行う。526に示したadd命令は、スタックポインタ専用命令であるスタックポインタ移動命令であり、スタックポインタを上方に移動させサブルーチン520で使用するスタック領域を確保する。該命令が実行されるとスタックポインタ(SP)はXバイトだけ上方の位置548に移動し(のSP)、注2)に示すサブルーチンが使用するオート変数の領域が確保される。

【0115】528はサブルーチン520でオート変数と汎用レジスタR0~R3を用いた処理を行うことを示している。このときスタックポインタの位置はGSPを指しており、オート変数のロードは、スタックポインタ専用命令であるSP専用ロード命令をもちいて行われる。

【0116】529は、メモリ上に格納されたオート変数S1を汎用レジスタR1に転送する前記SPロード命令を示している。前記オート変数S1はスタックボインタ(⑤SP)からYバイトだけオフセット値を有する場所に格納されている。前述したようにサブルーチンの528の処理の最中にはスタックボインタは移動しないので、オート変数のメモリアドレスは、スタックボインタ50

+オフセット値で特定され、前記SP専用ロード命令を 用いて効率良く汎用レジスタとのやり取りを行うととが できる。

【0117】また、サブルーチン520からメインプロ グラム500に戻る前には、スタックに待避されていた 汎用レジスタR0~R3の値を汎用レジスタR0~R3 に復帰させ、スタックボインタがメインルーチンへのリ ターンアドレスが格納されているエリア544を指すよ うにしなければならない。そのためにまず、526のス タックポインタ移動命令で移動させたスタックポインタ をもとの位置に戻してやる。530に示したsub命令 は、スタックボインタ専用命令であるスタックボインタ 移動命令であり、スタックポインタを下方に移動させ る。該命令が実行されると、スタックボインタは546 に移動する(GSP参照)。次にスタックに格納されて いる情報550を汎用レジスタR0~R3に復旧する処 理を行う。532は、スタックの情報を汎用レジスタR 0~R3に転送するする処理を行うスタックポインタ専 用命令である連続ポップ命令(popn)を示してい る。該命令が実行されるとスタックに格納されていた値 550が汎用レジスタRO~R3に連続的に転送され、 図4の550に示すように、スタック540に格納され る。との処理の実行が終わる(532句)と、スタック ポインタは544を指している(OSP参照)。

【0118】534はリターン命令を示している。前記リターン命令が実行されると、実行の制御はメインプログラム500にわたる。このとき本実施例では、前記スタックポインタ専用命令であるリターン命令(ret命令)が実行される。該命令が実行されると、②SPが指30 オスタックエリアに格納されたメインプログラムへのリターンアドレスが示す命令に分岐する、即ちメインプログラム500の次の命令507に戻る。そしてスタックポインタの値は自動的に+4だけインクリメントされメインプログラム500が使用するスタックの先頭エリアに移動する(図4の❸SP参照)。

【0119】以下前記各スタックポインタ専用命令についてそれぞれ命令の説明及び該命令を実行するための回路構成及び実行時の動き等について詳細に説明する。

【0120】(5)スタックボインタ相対ロード命令 前述したようにCコンパイラはオート変数の領域をスタックボインタに関連づけて記憶するオブジェクトコード を作成する。具体的には、CコンパイラはスタックボインタからオフセットがXのところにYバイトだけオート 変数の領域を確保する仕様になっている。

【0121】図5は、メモリ上のオート変数をレジスタ に転送する処理を説明するための図である。オート変数 a はワードデータ、オート変数 b、c はハーフワードデータ、オート変数 d~g はバイトデータである。SPに 格納されたスタックボインタはスタック上のオート変数 が格納される領域 600の先頭領域のアドレスである1

000を示している。オート変数aを格納するためのエリアとして前記スタックポインタをメモリアドレスとするスタック上のエリアが、オート変数b、cを格納するためのエリアとしてそれぞれスタックポインタ+2、スタックポインタ+4をメモリアドレスとするスタック上のエリアが、オート変数d~gを格納するためのエリアとしてそれぞれスタックポインタ+5、スタックポインタ+6、スタックポインタ+7、スタックポインタ+8をメモリアドレスとするスタック上のエリアが確保されている。そして所与の処理を実行する際には、スタックポインタ+オフセット値のメモリアドレスで特定されるオート変数と汎用レジスタ間でデータの転送処理が必要となる。

【0122】本実施例のCPUでは、このような転送処理を短いオブジェクトコードで記述し効率良く実行するために、スタックポインタ専用命令の一つであるSP相対ロード命令として、次に示す命令セットを用意している。

[0123]

- ld. b %Rd, [%sp+imm6] ...(1)
- ld. ub %Rd; [%sp+imm6] ... (2)
- ld. h %Rd, [%sp+imm7] ... (3)
- ld. uh %Rd, [%sp+imm7] ... (4)
- ld. w %Rd, [%sp+imm8] ... (5)
- ld. b [%sp+imm6], %Rs ... (6)
- ld. h [%sp+imm7], %Rs  $\cdots$  (7)
- ld. w [%sp+imm8], %Rs. ...(8)
- (1)~(8)は命令コードをアセンブラで記述したものである。(1)はスタックからバイトデータをサイン拡張してレジスタに転送する命令であり、(2)はスタックからバイトデータをゼロ拡張してレジスタに転送する命令であり、(3)はスタックからハーフワードデータをサイン拡張してレジスタに転送する命令であり、
- (4) はスタックからハーフワードデータをゼロ拡張してレジスタに転送する命令であり、(5) はスタックからワードデータをレジスタに転送する命令であり、
- (6)はレジスタからバイトデータをスタックに転送する命令であり、(7)はレジスタからハーフワードデータをスタックに転送する命令であり、(8)はレジスタからワードデータをスタックに転送する命令である。
- 【0124】 [%sp+imm6]、 [%sp+imm7]、 [%sp+imm8]は、それぞれ即値オフセット情報を 表しており、該即値オフセット情報に基づき実行時に生 成されるオフセット値とSP14に格納されたスタック ポインタの値を加算してメモリアドレスが生成される。

[%sp+imm6] はメモリ上のデータのデータサイズがパイトの時、[%sp+imm7] はメモリ上のデータのデータサイズがハーフワードの時、[%sp+imm8] はメモリ上のデータのデータサイズがワードの時の即値オフセット情報である。これらはいずれも、後述す

る図6(A)に示す用にオブジェクトコード上では6ビットの即値オフセット情報614として記述されている。しかし命令実行時には、imm7の場合(即ちデータサイズがハーフワードの場合)、即値オフセット情報614は1ビット左論理シフトしてスタックボインタに加算すべきオフセット値が生成される。また、imm8の場合(即ちデータサイズがワードの場合)、即値オフセット情報614は2ビット左論理シフトしてスタックボインタに加算すべきオフセット値が生成される。

24

[0125] とこにおいてスタックとはメモリに設けられた一時記憶領域をいい、前記メモリアドレスで、例えば図5に示すスタック上のオート変数(a~g)の位置を指定することができる。

[0126]図6(A)は、前記(1)~(8)のSP 相対ロード命令のビットフィールド610である。図6 (A) に示すようにSP相対ロード命令は、操作機能が メモリとレジスタ間のデータの転送であることを示すオ ペコード612 (6ビット)、即値で指定された即値オ フセット情報(6ピット)614と、転送対象となる汎 20 用レジスタのレジスタ番号616(4ピット)を含み、 16ビットのオブジェクトコードを有している。前記オ ペコード612はSP14を操作対象とするロード命令 であることを示す共通のコードと前記データサイズ、サ イン拡張及びゼロ拡張の別に応じて与えられる異なるコ ードとを含んでいる。従ってオペコードによりSP14 に格納されたスタックポインタを操作対象とすることが わかるため、オブジェクトコードのオペランドにスタッ クポインタに関する情報を必要としない。即値オフセッ ト情報614は転送対象となるデータのスタックポイン タからのオフセット値を生成するための情報である。と れは、前述したようにデータサイズを問わず6ビットで 指定される。転送対象となるレジスタのアドレス616 には、前記(1)~(5)の場合はスタックからよみだ されたデータが格納されるレジスタのレジスタ番号が、 前記(6)~(8)の場合はスタックに書き込まれるデ ータが格納されているレジスタのレジスタ番号が入って

[0127] 図6(B) はスタックポインタとして汎用レジスタを用いた場合に使用する汎用レジスタを操作対 象とするロード命令(以下汎用ロード命令という)のオブジェクトコードのビットフィールド620の例を示している

【0128】図6(B)に示すように汎用ロード命令は、操作機能がメモリと汎用レジスタ間のデータの転送であることを示すオペコード622(6ビット)、即値で指定された即値オフセット情報624(6ビット)とスタックポインタとして使用する汎用レジスタを特定する第一のレジスタ番号626(4ビット)と、転送対象となる汎用レジスタを特定する第二のレジスタ番号62 8(4ビット)を含み、20ビットのオブジェクトコー

ドを有している。汎用マイクロコンピュータでは命令長 は8ビット単位なので24ビット若しくは32ビット命 令になる。

25

【0129】図6(A)(B)は、いずれもスタックポ インタにオフセット値を加算して特定されるメモリアド レスとレジスタの間でのデータの転送処理を行う場合に 使用する命令のオブジェクトコードを示しているが、同 図に示すように、SP相対ロード命令は汎用ロード命令 に比べて短いオブジェクトコードで記述することができ

【0130】以下、スタックからレジスタにデータを転 送する命令として(5)の命令(スタックからレジスタ にワードデータを読み出す命令なので、以下ワードデー タ読み出しのSP相対ロード命令という)、レジスタか らスタックにデータを転送する命令として(8)の命令 (レジスタからスタックにワードデータを取り込む命令) なので、以下ワードデータ書き込みのSP相対ロード命 令という)を例にとりこれらの命令を実行するための構 成及び実行時の動作について説明する。

【0131】まず図1を用いてこれらの命令を実行する 20 ために必要なハードウエア構成について説明する。とれ らの命令は外部のメモリ(ROM)52よりI\_DAT A\_BUS94を介して伝送され、CPU10の命令デ コーダ20に入力される。該命令デコーダ20で、命令 が解読され命令の実行に必要な図示しない各種信号が出 力される。また前記即値生成器22は、データサイズに 応じて前記即値オフセット情報614の左論理シフトを 行い、必要に応じてサイン拡張及びゼロ拡張行い実行に 使用するオフセット値を生成し、PB\_BUS74に出 力する。SP14はスタックポインタを格納しており、 との値はアドレス加算器30の入力に接続されたXA\_ BUS78に出力できる。アドレス加算器30のもう一 方の入力は、即値生成器22の出力であるPB\_BUS 74に接続されている。アドレス加算器30の出力(A DDR) は、DA信号線84を介して外部のD\_ADD R\_BUS96に接続されている。

【0132】バスコントロールユニット(BCU)60 は、CPUから出力される各種リクエスト信号(外部バ スに出力された信号等)に基づき、スタックエリアを含 むメモリ (RAM、ROM) 50、52とのデータの入 40 出力を制御し、READ、WRITE制御信号を出力す

【0133】まずワードデータ読み出しのSP相対ロー ド命令の実行時の動作について説明する。

【0134】ワードデータ読み出しのSP相対ロード命 令が実行されると、SP14に格納されたスタックポイ ンタの値と、前記即値オフセット情報614に基づき即 値生成器22が生成したオフセット値が加算され、メモ リ読み出し用のメモリアドレスが生成される。そして該 メモリアドレスに基づきメモリ上の情報が読み出され、

オブジェクトコードの前記レジスタ番号616で特定さ れる汎用レジスタに転送される。

【0135】図7はワードデータ読み出しのSP相対ロ ード命令の動作を説明するためのフローチャート図であ

【0136】前記命令の実行の最初にSP14に格納さ れているスタックボインタがXA\_BUS78に出力さ れる(ステップ210)。また、即値生成器22が即値 オフセット情報から生成したオフセット値immがPB\_ 10 BUS74に出力される(ステップ212)。アドレス 加算器30は、前記XA\_BUS78上の値と前記PB ■BUS74上の値を加算し、結果(ADDR)である メモリの読み出しアドレスをDA信号線84を介してD \_ADDR\_BUS96に出力する (ステップ214、 ステップ216)。そしてCPUからBCU60へのデ ータ読み出しリクエスト信号がアクティブになり、外部 メモリのリードサイクルを実行する (ステップ21 8)。即ち前記BCU60は該リクエスト信号に基づ き、前記読み出しアドレスをメモリアドレスとしてメモ リからデータが読み出され、D\_DATA\_BUS98 に出力されるよう制御する。 D\_DATA\_BUS98 上のデータはDIN信号線86を介してWW\_BUS7 6 に出力される (ステップ220)。 そしてWW\_BU S76上の値は命令コードの転送対象となるレジスタ (Rs/Rd)のアドレス(4ビット)616で指定さ れたレジスタ番号を有するレジスタ(%Rd)に格納さ れる(ステップ222)。

【0137】次にワードデータ書き込みのSP相対ロー ド命令の実行時の動作について説明する。

【0138】ワードデータ書き込みのSP相対ロード命 令が実行されると、SP14に格納されたスタックポイ ンタの値と、前記即値オフセット情報614に基づき即 値生成器22が生成したオフセット値が加算され、メモ リ書き込み用のメモリアドレスが生成される。そしてオ ブジェクトコードの前記レジスタ番号616で特定され る汎用レジスタに格納されている情報が、該メモリアド レスに基づき特定されるメモリ上のエリアに転送され る。

【0139】図8はワードデータ書き込みのSP相対ロ ード命令の動作を説明するためのフローチャート図であ る。

【0140】前記命令の実行の最初にSP14に格納さ れているスタックポインタがXA\_BUS78に出力さ れる(ステップ230)。また、即値生成器22が即値 オフセット情報から生成したオフセット値immがPB BUS74に出力される(ステップ232)。アドレス 加算器30は、前記XA\_BUS78上の値と前記PB \_BUS74上の値を加算し、結果(ADDR)である メモリへの書き込みアドレスをDA信号線84を介して 50 D\_ADDR\_BUS 9 6 に出力する (ステップ 2 3

4、ステップ236)。また、命令コードの転送対象となるレジスタ(Rs/Rd)のアドレス(4ビット)6 16で指定されたレジスタ番号を有するレジスタ(%Rd)に格納されているデータがPA\_BUS72に出力される(ステップ238)。PA\_BUS72上のデータはDOUT信号線88を介して、D\_DATA\_BUS98に出力される(ステップ240)。そしてCPUからBCU60へのデータ書き込みリクエスト信号がアクティブとなり、外部メモリのライトサイクルを実行する(ステップ242)。即ち前記BCU60は前記リクエスト信号に基づき、前記書き込みアドレスをメモリアドレスとして、D\_DATA\_BUS98で転送されてきたデータをメモリ50に書き込む動作を制御する。

【0141】(6)スタックポインタ移動命令 図9(A)~(F)は、複数のルーチンにわたってプログラムが実行される場合の各ルーチンによるメモリ上のスタックの使用状態及びスタックポインタの状態を説明するための図である。

[0]42]図9(A)に示すMAINルーチン210の所与の処理 a の実行時におけるメモリ上のスタック領域の状態及びスタックポインタ(SP14に格納されている値)の状態を図9(D)に示している。222はMAINルーチン210で使用するためのスタック領域を示しており、スタックポインタは222の先頭アドレス232を示している。

【0143】図9(B)のSUB1ルーチン212は、前記MAINルーチン210から呼ばれて実行されるサブルーチンである。該SUB1ルーチン212の所与の処理b213の実行時におけるメモリ上のスタック領域の状態及びスタックポインタ(SPに格納されている値)の状態を図9(E)に示している。224はSUB1ルーチン212で使用するためのスタック領域を示しており、スタックポインタは224の先頭アドレス234を示している。

[0144]図9(C)のSUB2ルーチン214は、前記SUB1ルーチン210から呼ばれて実行されるサブルーチンである。該SUB2ルーチン214の所与の処理c215の実行時におけるメモリ上のスタック領域の状態及びスタックポインタ(SPに格納されている値)の状態を図9(F)に示している。226はSUB 402ルーチン214で使用するためのスタック領域を示しており、スタックポインタは226の先頭アドレス236を示している。

[0]45] とのように複数のサブルーチンにわたって 実行が行われる場合、各ルーチンで使用するスタック領 域が移動するため、それに伴いスタックボインタの値 を、各ルーチンで使用するスタック領域の先頭に移動す ることが行われる。

【0146】本実施例のCPUでは、とのようなスタックポインタの移動処理を短いオブジェクトコードで記述 50

し効率良く実行するために、スタックボインタ専用命令 の一つであるスタックポインタ移動命令として、次に示 す命令セットを用意している。

[0147]

add %sp, imm12  $\cdots$  (9) sub %sp, imm12  $\cdots$  (10)

(9) (10) は命令コードをアセンブラで記述したものである。(9) はSP14に格納されたスタックボインタに対する即値加算命令であり、(10) はSP14 に格納されたスタックボインタに対する即値減算命令である。inm12は、命令のオブジェクトコードに含まれた10ビットの即値を2ビット左方向にシフトした後、ゼロ拡張されて32ビットデータとなり、SP14に格納されたスタックボインタとの演算に用いられる。

【0148】図10(A)は、前記(9)(10)のス タックポインタ移動命令のビットフィールド630であ る。図10(A)に示すようにスタックポインタ移動命 令は、操作機能がSP14 に格納されたスタックポイン タへの移動情報の加算及び減算であることを示すオペコ 20 ード632(6ビット)、即値で指定された即値移動情 報634(10ビット)を含み、16ビットのオブジェ クトコードを有している。前記オペコード632はSP 14を操作対象とするスタックポインタ移動命令である ととを示す共通のコードと加算及び減算の別に応じて与 えられる異なるコードとを含んでいる。従ってオペコー ドによりSP14に格納されたスタックポインタを操作 対象とすることがわかるため、オブジェクトコードのオ ベランドにスタックポインタに関する情報を必要としな い。即値移動情報634はスタックポインタに加算又は 30 減算を行うオフセット値を生成するための情報である。 【0149】図10 (B) はスタックポインタとして汎 用レジスタを用いた場合に使用する加算及び減算命令 (以下汎用演算命令という) のオブジェクトコードのビ ットフィールド640の例を示している。

【0150】図10(B)に示すように汎用演算命令は、操作機能が汎用レジスタの値への即値演算情報の加算及び減算であることを示すオペコード642(6ビット)、即値で指定された即値演算情報644(10ビット)と操作対象となる汎用レジスタを特定するレジスタ番号646(4ビット)とを含み、20ビットのオブジェクトコードを有している。汎用マイクロコンピュータでは命令長は8ビット単位なので24ビット若しくは32ビット命令になる。

【0151】図10(A)(B)は、いずれもスタックボインタに即値を加算及び減算する処理を行う場合に使用する命令のオブジェクトコードであるが、同図に示すように、スタックボインタ移動命令は汎用演算命令に比べて短いオブジェクトコードで記述することができる。【0152】以下、(9)のSPに対する即値加算命令(以下加算スタックボインタ移動命令という)と、(1

30

0)のSPに対する即値減算命令(以下減算スタックボインタ移動命令という)を実行するための構成及び実行時の動作について説明する。

29

【0153】まず図1を用いてこれらの命令を実行する ために必要なハードウエア構成について説明する。これ ちの命令は外部のメモリ(ROM)52よりI\_DAT A\_BUS94を介して伝送され、CPU10の命令デ コーダ20に入力される。該命令デコーダ20で、命令 が解読され命令の実行に必要な図示しない各種信号が出 力される。また前記即値生成器22は、前記即値移動情 10 報634の10ビットを2ビット左論理シフトし、ゼロ 拡張してPA\_BUS72に出力する。SP14はスタ ックポインタを格納しており、この値はXA\_BUS7 8に出力される。XA\_BUS78はALU40の入力 となるPB\_BUS74に接続されている。ALU40 のもう一方の入力は、即値生成器22の出力であるPA \_\_BUS72に接続されている。ALU40の出力は、 WW\_BUS76に接続されている。WW\_BUS76 はSPの入力に接続されている。

【 0 1 5 4 】まず加算スタックポインタ移動命令の実行 時の動作について説明する。

【0155】加算スタックボインタ移動命令が実行されると、SP14に格納されたスタックボインタの値と、前記即値移動情報634に基づき即値生成器22が生成した移動即値が加算されて新たなスタックボインタが生成され、その値がSP14に格納される。

【0156】図11は加算スタックポインタ移動命令の動作を説明するためのフローチャート図である。

【0157】前記命令の実行の最初にSP14に格納されているスタックボインタがXA\_BUS78に出力される(ステップ250)。そして前記XA\_BUS78上のデータはPB\_BUS74に出力される(ステップ252)。また、即値生成器22が即値移動情報に基づき生成した移動即値immがPA\_BUS72に出力される(ステップ254)。ALU40は、前記PB\_BUS74上の値と前記PA\_BUS72上の値を加算し、結果をWW\_BUS76に出力する(ステップ256)。そして、WW\_BUS76上の値がSP14に入力される(ステップ258)。

【0158】次に減算スタックポインタ移動命令の実行時の動作について説明する。

【0159】減算スタックポインタ移動命令が実行されると、SP14に格納されたスタックポインタの値から、前記即値移動情報634に基づき即値生成器22が生成した移動即値が減算されて新たなスタックポインタが生成され、その値がSP14に格納される。

【 0 1 6 0 】 図 1 2 は減算スタックボインタ移動命令の動作を説明するためのフローチャート図である。

【0161】前記命令の実行の最初にSP14に格納されているスタックポインタがXA\_BUS78に出力さ

れる(ステップ260)。そして前記 $XA_BUS78$ 上のデータは $PB_BUS74$ に出力される(ステップ262)。また、即値生成器22が即値移動情報に基づき生成した移動即値 i mmが $PA_BUS72$ に出力される(ステップ264)。ALU40は、前記 $PB_BUS74$ 上の値から前記 $PA_BUS72$ 上の値を減算し、結果を $WW_BUS76$ に出力する(ステップ266)。そして、 $WW_BUS76$ 上の値がSP14に入力される(ステップ268)。

【0162】(7)分岐命令

図13は、call命令とret命令によるプログラム の実行の制御を説明するための図である。図13に示す ように、MAINルーチン300において、サブルーチ ンSUB310へ分岐するためのcall命令が実行さ れると(302)、制御がサブルーチンSUB310に 渡る。サブルーチンの最後には、ret命令(312) が書かれており、との命令が実行されると、MAINル ーチン300の前記call命令(302)の次の命令 (304) に戻る。従って、図13に示す場合の②③の 順でプログラムが実行されることになる。このようにサ ブルーチンSUB310での実行が終わるとMAINル ーチン300に戻り、前記call命令(302)の次 の命令(304)から実行するため、サブルーチンSU B310に分岐する際、どこかに戻り先のアドレスを記 憶しておくことが必要となる。とのため、call命令 等のサブルーチンへ分岐する分岐命令実行の際には、図 4で説明したように戻り先アドレスをスタックに待避す る処理が行われ、ret命令等のサブルーチンから戻る 分岐命令の実行の際には前記スタックから戻り先アドレ スをプログラムカウンタに戻す処理(以下プログラムカ ウンタの待避及び復旧の処理という)が行われる。

【0163】従来のRISC方式のCPUでは、前記プログラムカウンタの待避及び復旧の処理をソフトウエア的に実現していたため、call命令等の分岐命令を実行する際には、これらの処理を実行するためオブジェクトコード(アセンブラ命令)も必要であった。例えばcall命令を実行する際には、スタックポインタをワードサイズ(4)だけデクリメント(-4)して、プログラムカウンタの値に基づきcall命令の次の命令のアドレスをスタックに格納するためのオブジェクトコード(アセンブラ命令)が必要であった。

【0164】しかし本実施例のCPUは、前記call命令やret命令が実行されると、前記プログラムカウンタの待避及び復旧の処理も一緒に行うようなハードウエア構成を有している。従って、前記call命令やret命令と別に、前記プログラムカウンタの待避及び復旧の処理を記述するオブジェクトコード(アセンブラ命令)を必要としない。本実施例のCPUでは、このような前記プログラムカウンタの待避及び復旧の処理を一命50令で実行するために、スタックボインタ専用命令の一つ

である分岐命令として次に示す命令セットを用意してい

31

[0165] call sign9 ... (11) ... (12) call %Rb ret ... (13) ... (14) reti retd ... (15) ... (16) int imm2 ... (17) brk

(11)~(17)は命令コードをアセンブラで記述し たものである。(11)はPC相対サブルーチンコール 命令で、プログラムカウンタPCをベースアドレスとし て、オペランドで指定されたディスプレースメント情報 sign9に基づき分岐先アドレスを相対的に指定して分岐 するコール命令である。(12)はレジスタ間接サブル ーチンコール命令であり、オペランドで指定されたレジ スタに格納されている分岐先アドレスに分岐するコール 命令である。(13)はサブルーチンからのリターン命 令である。(14)は割り込み又は例外処理ルーチンか らのリターン命令である。(15)はデバッグ処理ルー チンからのリターン命令である。(16)はソフトウエ ア割り込み命令である。 (17) はソフトウエア・デバ ッグ割り込み命令である。

【0166】図14は、前記(11)のPC相対サブル ーチンコール命令のビットフィールド650である。図 14に示すようにPC相対サブルーチンコール命令は、 操作機能がプログラムカウンタをベースアドレスとし て、分岐先アドレスを相対的に指定してサブルーチンへ 分岐するコール命令であることを示すオペコード652 (8ビット)、即値で指定されたディスプレースメント 情報sign9 (8ビット) 654とを含み、16ビットの オブジェクトコードを有している。前記8 ビットの即値 は、実行時に1ビット左に論理シフトされた後、サイン 拡張される。

【0167】本実施例のCPUでは、call命令実行 には図14に示すオブジェクトコードのみで、プログラ ムカウンタのスタックへの待避も実行することが出来 る。

【0168】以下、サブルーチンへ分岐する命令として (11)のPC相対サブルーチンコール命令、サブルー チンからリターンする命令として(13)のリターン命 令を例にとりこれらの命令を実行するための構成及び実 行時の動作について説明する。

【0169】まず図1を用いてこれらの命令を実行する ために必要なハードウエア構成について説明する。とれ ちの命令は外部のメモリ(ROM) 52よりI\_DAT A\_BUS94を介して伝送され、CPU10の命令デ コーダ20に入力される。該命令デコーダ20で、命令 が解読され命令の実行に必要な図示しない各種信号が出 力される。また前記即値生成器22は、前記ディスプレ 50 される。

ースメント情報654を1ビット左に論理シフトした後 サイン拡張して32ビットの即値ディスプレースメント immを生成し、PB\_BUS74に出力する。SP1 4はスタックポインタを格納しており、この値はアドレ ス加算器30の入力に接続されたXA\_BUS78に出 力できる。アドレス加算器30のもう一方の入力は、即 値生成器22の出力であるPB\_BUS74に接続され ている。アドレス加算器30の出力(ADDR)は、1 A信号線82を介して外部の1\_ADDR\_BUS92 に接続されている。

32

[0170]また、I\_ADDR\_BUS92及びI\_ DATA\_BUS94は命令のオブジェクトコードが格 納されたROM52に接続されており、バスコントロー ルユニット (BCU) 60は、CPUから出力される各 種リクエスト信号 (外部バスに出力された信号等) に基 づき、メモリ(ROM)52から前記命令のオブジェク トコードを読み出すREAD制御信号を出力する。

[0171]まずPC相対サブルーチンコール命令の実 行時の動作について説明する。

【0172】PC相対サブルーチンコール命令が実行さ れると、図4で説明したように、PC12に格納された プログラムカウンタの値がスタックに待避され、SP1 4 に格納されたスタックポインタの値がワードサイズ (4) だけディクリメントされる。そしてPC12にプ ログラムカウンタと前記32ビットの即値ディスプレー スメントを加算して得られた分岐先アドレスがセットさ れる。

【0173】図15はPC相対サブルーチンコール命令 の動作を説明するためのフローチャート図である。

【0174】前記命令の実行の最初にSP14に格納さ れているスタックポインタがXA\_BUS78に出力さ れる(ステップ270)。とれはアドレス加算器の一方 の入力となり、即値生成器22が生成したconstantデー タ (-4)がアドレス加算器30の他方の入力となる。 そしてアドレス加算器30で前記XA\_BUS78上の スタックポインタの値と-4を加算して戻りアドレスを 格納するスタックへの書き込みアドレス生成され、WW \_BUS76に出力される。また、前記書き込みアドレ スはDA信号線84を介してD\_ADDR\_BUS96 に出力される。(ステップ272)。また、PCインク リメンタ44ではPC12に格納されたプログラムカウ ンタの値が+2されて戻りアドレスが生成されて、D〇 UT信号線888を介してD\_DATA\_BUS98に出 力される(ステップ274)。そしてCPUからBCU 60へのデータ書き出しリクエスト信号がアクティブに なり、外部メモリのライトサイクルを実行する(ステッ プ276)。即ち前記BCU60は該リクエスト信号に 基づき、前記書き込みアドレスをメモリアドレスとして メモリに設けられたスタックに前記戻りアドレスが格納 [0175] そして、 $WW_BUS76$  上の値がSP14 に出力される (ステップ278)。 すなわちスタックボインタの値が -4 した値に更新される。

【0176】次にPC12に格納されているプログラム カウンタがXA\_BUS78に出力される(ステップ2 80)。また、前記即値生成器22は、命令のオブジェ クトコードに含まれている前記ディスプレースメント情 報654を1ビット左に論理シフトした後サイン拡張し て32ビットの即値ディスプレースメント i mmを生成 し、PB\_BUS74に出力する。前記アドレス加算器 10 30はXA\_BUS78上のプログラムカウンタとPB \_ BUS74上の即値ディスプレースメントimmを加 算し分岐アドレス(ADDR)を生成し、IA信号線8 2を介して、I\_ADDR\_BUS92に出力する(ス テップ282)。そしてCPUからBCU60への命令 読み出しリクエスト信号がアクティブとなり、外部メモ リ(ROM)52のリードサイクルを実行し、分岐先の 命令のオブジェクトコードを読み出す(ステップ28 4).

【0177】次にret命令の実行時の動作について説 20 明する。

【0178】ret命令が実行されると、図4で説明したように、スタックに待避されていたプログラムカウンタの値がPC12に復帰され、SP14に格納されたスタックポインタの値がワードサイズ(4)だけインクリメントされる。

[0179]図]6はretの動作を説明するためのフローチャート図である。

【0180】前記命令の実行前には、SP14に格納さ れたスタックポインタは呼ばれたルーチンへの戻り先ア ドレスが格納されたスタックのアドレスをさしている。 【0181】前記命令の実行の最初にSP14に格納さ れているスタックポインタがXA\_BUS78に出力さ れる(ステップ290)。そしてXA\_BUS78上の スタックポインタはD\_ADDR\_BUS96に出力さ れる (ステップ292)。そしてCPUからBCU60 へのデータ読み込みリクエスト信号がアクティブにな り、外部メモリのリードサイクルを実行する。即ち前記 BCU60は該リクエスト信号に基づき、前記スタック ポインタをメモリアドレスとしてメモリに設けられたス 40 タックから前記戻りアドレスを読み出す。メモリ(RA M) 50から読み出された前記戻り先アドレスはD\_D ATA BUS94からDIN信号線86を介してCP U内部にとりとまれ、さらにDIN信号線からIA信号 線82を介して1\_ADDR\_BUS92に出力される (ステップ294)。そしてCPUからBCU60への 命令読み出しリクエスト信号がアクティブとなり、外部 メモリ(ROM)52のリードサイクルを実行し、戻り 先アドレスの命令のオブジェクトコードを読み出す(ス テップ296)。

【0182】そして、XA\_BUS78上のスタックボインタの値は、前記アドレス加算器30の一方の入力となる。また即値生成器22が生成したconstantデータ(+4)がアドレス加算器30の他方の入力となる。そしてアドレス加算器30で前記XA\_BUS78上のスタックボインタの値と+4を加算して、戻り先のルーチンが確保したスタック領域の先頭エリアのアドレスが生成され、WW\_BUS76上の前記アドレス(戻り先のルーチンが確保したスタック領域の先頭エリアのアドレス)がSP14に出力される(ステップ30の)。

34

[0183] (8) 連続プッシュ命令 (pushn)、連続ポップ命令 (popn) の説明

前述したように、最近の特にRISC方式のCPUは、性能を高めるため内部に多くの汎用レジスタを持ち、メモリにアクセスすることなくCPU内部で高速に多くの処理をおこなうよう構成されている。本実施例でも内部に16本の汎用レジスタをもち、処理の高速化を図っている。しかし、このように内部レジスタを多く持つと、割り込み処理やサブルーチンコールの時のレジスタ退避と復旧の処理の際、退避すべきレジスタ数が多くなる。【0184】このようなレジスタの待避や復旧を行う場合、従来は、番地部で指定した内容をスタックに格納するpush命令や、スタックの内容をレジスタに取り出すpop命令を用いていた。ここで一般的なpush命令及びpop命令時の動きを説明する。

【0185】図17(A)(B)はpush命令実行時の動きを模式的に示した図であり、図18(A)(B)はpop命令実行時の動きを模式的に示した図である。図17(A)(B)及び図18(A)(B)を用いて、複数の汎用レジスタとスタック間でデータの転送を行う場合の動きを説明する。

【0186】図17(A)は、汎用レジスタR1の内容をスタックに書き出す命令である。push R1 が実行された場合の動きを示している。該命令の実行時には、SP14の内容は現在の値から4がひかれた値に更新される(図17(A)に示すように1000が996に更新される)。そして、更新されたSP14のスタックポインタが示すメモリアドレスである996に汎用レジスタR1の内容aが書き込まれる。

[0187]図17(B)は、さらに汎用レジスタR2の内容をスタックに書き出す命令である push R2 が実行された場合の動きを示している。該命令の実行時には、SP14の内容は現在の値から4がひかれた値に更新される(図17(B)に示すように996が992に更新される)。そして、更新されたSP14のスタックボインタが示すメモリアドレスである992に汎用レジスタR2の内容bが書き込まれる。

50 【0188】図18(A)は、スタックの内容を汎用レ

ジスタR 2 に取り出す命令である'pop R 2'が実行された場合の動きを示している。該命令の実行時には、SP14のスタックポインタが示しているメモリアドレス992 に格納されている内容 b がとりだされて汎用レジスタR 2 に格納される。そしてSP14の内容は現在の値に4が足された値に更新される(図18(A)示すように実行前992であったのが実行後996に更新される)。

【0189】図18(B)は、更にスタックの内容を汎用レジスタR 1 に取り出す命令である pop R 1 が実行された場合の動きを示している。該命令の実行時には、SP14 のスタックポインタが示しているメモリアドレス996 に格納されている内容 a がとりだされて汎用レジスタR 1 に格納される。そしてSP14 の内容は現在の値に4 が足された値に更新される(図18

(B) に示すように実行前996であったのが実行後1000に更新される)。

【0190】とのように従来は、複数の汎用レジスタとスタックでデータの転送を行う場合、push命令やpop命令を複数回繰り返して実行することが必要であった。push命令やpop命令は1回の命令で1本のレジスタしか操作することができなかったからである。

【0191】従って多数のレジスタに対してスタックへの待避やスタックからの復旧処理を行う場合、命令数の増加によりオブジェクトコードのサイズの増大を招いていた。また、プログラムの実行ステップも多くなり、プログラムの実行時間や処理動作の遅延を招いていた。

[0192] そとで 本実施例のCPUでは、次に示す 命令セットを用意している。

[0193] pushn %Rs ... (18) popn %Rd ... (19)

(18)は連続ブッシュ命令のアセンブラの記述を示し M) 5 でおり、%R s からR O までのn個(nは1から16の ITE 自然数)の汎用レジスタの内容を連続的にスタックへフッシュする命令である。(19)は連続ポップ命令のアセンブラの記述を示しており、スタックからn個(nは 1から16の自然数)のワードデータを連続的に%R d れるとからR O までの汎用レジスタへボップする命令である。 p u s h n、p o p n 命令は、いずれもオペコードとオペランドからなる。%R s は p u s h n 命令のオペラン 40 る。ドでレジスタ%R s からR O までをスタックに書き込む場合のR s のレジスタ番号を示している。%R d は p o p n 命令のオペランドでR O から%R d 迄のレジスタにスタックからデータを持ってくる場合のR d のレジスタに信号2番号を示している。

【0194】図19にpushn、popn命令のビットマップを示す。下位の4ビットのフィールドに%Rsまたは%Rdを示すコードが入り、16本ある汎用レジスタの任意のレジスタが指定できる。特殊レジスタとスタックの間でデータの転送をするときは、汎用レジスタ 50

を介して行う。

【0】95】図20は連続プッシュ命令(push n)、連続ポップ命令(popn)を実行するためのハ ードウェア構成を説明するためのブロック図である。図 1から連続プッシュ命令 (pushn)及び連続ポップ 命令(popn)の説明に必要な部分を取り出して、説 明に必要な部分を追加した構成になっている。図1と同 一部分を指すものについて同一の番号を付している。図 中11はR0からR15の16本の汎用レジスタであ 10 る。汎用レジスタ11はデータバス(D\_DATA\_B US)98とデータの入出力を行う。またレジスタを選 択するレジスタ選択アドレス信号54はコントロール回 路プロック45から来る。14はSPでスタックポイン タが格納されている。SP14の値はアドレスバス(D \_ADDR\_BUS)96と32ビットのアドレス加算 器30の入力に接続する内部アドレスバス(XALBU S) 78に出力できる。アドレス加算器30のもう一方 の入力はコントロール回路ブロック45からの出力され るオフセット信号24に接続されている。アドレス加算 20 器30の出力はラッチ(Add\_LT)32でラッチさ れ、さらにXA\_BUS78または♥♥\_BUS76に 出力される。WW\_BUS 7 6 はSP 1 4 の入力に接続 されている。コントロール回路ブロック45の中には4 ビットのカウンタ(countx)46があり、転送す るレジスタ数をカウントする。又、コントロール回路ブ ロック45中には図20では示されていないがインスト ラクションレジスタがあり、pushn、popn命令 のオペランド%Rs、%Rdを保持するとともに、イン ストラクションデコーダによって各命令に応じた制御信 30 号を出力する。図中60はバスコントロールユニット (BCU) で外部のスタックエリアを含むメモリ(RA M) 50とのデータの入出力を制御し、READ、WR JTE制御信号を出力する。

> 【0196】まず連続プッシュ命令(pushn)の実 行時の動作について説明する。

> [0197]連続プッシュ命令(pushn)が実行されると、図4で説明したように、%Rsのレジスタ番号の汎用レジスタから汎用レジスタR0までの汎用レジスタに格納された内容が連続的にスタックにプッシュされ

【0 198】図21はpushn命令の動作を説明するためのフローチャート図である。

[0199] pushn命令の実行の最初にオフセット信号 24 のoffsetは - 4 になる。カウンタ(countx)46 はゼロにクリアされ、SP14 に格納されたスタックボインタ値が $XA_BUS78$  に出力される(ステップ100)。

[0200]次にアドレス加算器30はXA\_BUS7 8上の値と-4を加算し結果をラッチ(Add\_LT) 32に入れる(ステップ101)。

【0201】ラッチ(Add\_LT)32の値はアドレ スパスD\_ADDR\_BUS96に出力される。コント ロール回路プロック45ではインストラクションレジス タの下位4ビットに保持された%Rsとカウンタ(co untx)46の差を計算し結果をレジスタ選択アドレ ス信号54に出力する。54によって選択されたレジス タをデータバス (D\_DATA\_BUS) 98にのせ、 外部メモリ(RAM)50の書き込み動作をする(ステ ップ102)。

37

【0202】ステップ103では、カウンタ(coun 10 tx) 46と%Rsを比較する。等しいときはレジスタ の外部メモリへの書き込みは完了しており、ラッチ(A dd\_LT) 32の値をWW BUS76を通じてSP 14に書き込んでpushnの実行を終わる(ステップ 104).

【0203】等しくないときはカウンタ(count x)をプラス1し、ラッチ (Add\_LT) 32の値を XA\_BUS78に出力し、ステップ101以降の処理 を繰り返す(ステップ105)。

【0204】次に連続ポップ命令(popn)の実行時 20 の動作について説明する。

【0205】連続ボップ命令(popn)が実行される と、図4で説明したように、スタックの内容が汎用レジ スタR0から%Rdのレジスタ番号の汎用レジスタに連 続的にプッシュされる。

【0206】図22は、popn命令の動作を説明する ためのフローチャート図である。

【0207】popn命令の最初にオフセット信号24 は+4になる。カウンタ(countx)46はゼロク リアされ、SP14のスタックポインタの値がXA\_B US78とアドレスパス (D\_ADDR\_BUS) 96 に出力される(ステップ110)。

【0208】次にアドレス加算器30はXA\_BUS7 8上の値と+4を加算し結果をラッチ(Add\_LT) 32に入れる(ステップ]]])。

【0209】次に外部メモリのリードサイクルを実行す る。リードされたデータはデータバス(D\_DATA\_ BUS)98を通じて汎用レジスタ11に書き込まれ る。このときコントロール回路ブロック45ではカウン タ(countx)46をレジスタ選択アドレス信号5 4に出力する(ステップ112)。

【0210】ステップ113では、カウンタ (coun tx) 46と%Rsを比較する。等しいときはレジスタ の外部メモリへの鬱き込みは完了しており、ラッチ(A dd\_LT)32の値をWW\_BUS76を通じてSP 14に書き込んでpopnの実行を終わる(ステップ) 14).

【0211】等しくないときはカウンタ(count x)をプラス1し、ラッチ (Add\_LT)32の値を S)96に出力し、ステップ111以降の処理を繰り返 す(ステップ115)。

[0212] とのように' pushn %Rs' で%R sからROまでのレジスタをスタックに書き込め、ま た'popn %Rd'でスタックから必要な個数のデ ータをROから%Rdまでのレジスタに戻すことが出来 る。たとえば、'pushn%R3'の実行によりレジ スタR3からR0までを一命令でプッシュできる。

【0213】ととにおいてレジスタの使い方に一つの制 約を加えることで、更に有効な効果が発生する。即ち、 レジスタの待避や復旧は割り込み処理やサブルーチンコ ール時等のプログラムが他のルーチンに分岐するときに 特に必要になるが、このとき他の割り込みルーチンまた はサブルーチン等の呼び出されるルーチンではレジスタ をROから順に使って行くことが好ましい。このように すると、ROからRdまたはRsに退避の必要のないレ ジスタが含まれず、pushn命令及びpopn命令を 用いて、効率的にレジスタの待避又は復帰を行うことが できる。本実施例ではレジスタはどれも同じ機能を持っ ており、レジスタの使い方と命令には何の制約も無いの で、このような制約は何の問題もなく満たすことが出来

【0214】従って本実施例のpushn命令及びpo pn命令を用いることにより、レジスタからメモリ中の スタックへの退避、またスタックからレジスタへのデー タの復旧がpushn、popnの各々一命令で実行で きる。とのためオブジェクトコードサイズやプログラム 実行ステップを最少にし、かつ実行サイクルを一回の命 令フェッチと必要な回数のデータの転送だけですませ、 最少のサイクルで行うことが出来る。これにより割り込 み処理ルーチンやサブルーチンの処理も高速化を図ると とができる。

【0215】一方、これを実現する構成要素はカウント 手段と簡単なシーケンス制御のみであり、少ないゲート 数で実現出来、ワンチップのマイクロコンピュータに適 したものである。

【0216】また、本実施例ではスタックポインタ専用 のレジスタSP14を用いた場合の連続プッシュ命令 (pushn)、連続ポップ命令(popn)を実行さ せるための構成について説明したが、スタックポインタ として汎用レジスタを使用する場合にも適用可能であ

【0217】(実施例2)図23は、本実施例のマイク ロコンピュータのハードウエアプロック図である。

【0218】該マイクロコンピュータ2は、32ビット・ マイクロコントローラであり、CPU10とROM52 とRAM50、高周波発振回路910、低周波発振回路 920、リセット回路930、プリスケーラ940、1 6ピットプログラマブルタイマ950、8ビットプログ XA\_BUS78とアドレスパス(D\_ADDR\_BU 50 ラマブルタイマ960、クロックタイマ970、インテ

リジェントDMA980、高速DMA990、割り込み コントローラ800、シリアルインターフェース81 0、バスコントロールユニット(BCU)60、A/D 変換器830、D/A変換器840、入力ポート85 0、出力ポート860、1/0ポート870、及びそれ らを接続する各種バス92、94、96、98、各種ピ ン890等を含む。

39

[0219] 前記CPU10は、スタックポインタ専用 レジスタであるSPを有し、前述した各種のスタックボ インタ専用命令の解読、実行を行う。該CPU10は、 前述した、実施例1の構成を有しており、前記解読手 段、前記実行手段として機能する。

【0220】従って本実施例のマイクロコンピュータ は、スタックポインタを取り扱う処理を、短い命令長で 効率よく記憶し、実行することができる。

【0221】また、レジスタ退避やレジスタ復旧の処理 を効率よく記憶し、割り込み処理及びサブルーチンコー ル・リターンの処理を高速に行うことができる。

【0222】本発明のマイクロコンピュータは例えばプ リンター等のパソコン周辺機器や、携帯機器等の各種の 20 示す。 電子機器に適用可能である。との様にすると、簡単な構 成でメモリの使用効率がよく高速に処理の行える情報処 理回路を内蔵することができるため、安価で高機能な電 子機器を提供することが出来る。

【0223】なお本発明は、上記実施例で説明したもの に限らず、種々の変形実施が可能である。

[0224]

#### 【図面の簡単な説明】

【図1】本実施例のCPUの回路構成の概略を説明する ための図である。

【図2】本実施例のCPUの持つレジスタセットを示

【図3】スタックポインタの一般的な動作について説明 するための図である。

【図4】スタックポインタ専用命令の使用例とメモリに もうけられたスタックの使用状態及びスタックポインタ の状態について説明するための図である。

【図5】メモリ上のオート変数をレジスタに転送する処 理を説明するための図である。

【図6】図6(A)(B)は、SP相対ロード命令及び 40 汎用ロード命令のビットフィールドを示した図である。

【図7】ワードデータ読み出しのSP相対ロード命令の 動作を説明するためのフローチャート図である。

【図8】ワードデータ書き込みのSP相対ロード命令の 動作を説明するためのフローチャート図である。

【図9】図9(A)~(F)は、複数のルーチンにわた ってプログラムが実行される場合の各ルーチンによるメ モリ上のスタックの使用状態及びスタックポインタの状 態を説明するための図である。

【図10】図10(A)(B)は、スタックポインタ移 50 82、84、86、88 内部信号線

動命令及び汎用演算命令のビットフィールドを示した図 である。

【図11】加算スタックポインタ移動命令の動作を説明 するためのフローチャート図である。

【図12】減算スタックボインタ移動命令の動作を説明 するためのフローチャート図である。

【図13】call命令とret命令によるプログラム の実行の制御を説明するための図である。

[図]4]PC相対サブルーチンコール命令のビットフ 10 ィールドを示した図である。

【図15】PC相対サブルーチンコール命令の動作を説 明するためのフローチャート図である。

【図16】 re t命令の動作を説明するためのフローチ ャート図である。

【図 1 7 】図 1 7 (A) (B) は p u s h 命令実行時の 動きを模式的に示した図である。

【図18】図18(A)(B)はpop命令実行時の動 きを模式的に示した図である。

【図19】pushn、popn命令のビットマップを

【図20】連続プッシュ命令(pushn)、連続ポッ プ命令(рорп)を実行するためのハードウェア構成 を説明するためのブロック図である。

【図21】pushn命令の動作を説明するためのフロ ーチャート図である。

【図22】popn命令の動作を説明するためのフロー チャート図である。

【図23】本実施の形態のマイクロコンピュータのハー ドウエアブロック図である。

#### 【符号の説明】 30

マイクロコンピュータ

10 CPU

11 汎用レジスタ

12 PC(プログラムカウンタ)

13 PSR (プロセッサステータスレジスタ)

20 命令デコーダ

22 即値生成器期

24 オフセット信号

30 アドレス加算器

40 ALU

44 PCインクリメンタ

45 コントロール回路ブロック

46 4ビットカウンタ (countx)

**50 メモリ(RAM)** 

52 メモリ(ROM)

54 レジスタ選択アドレス信号

60 バスコントロールユニット (BCU)

72、74、76、78 内部バス

【図1】





【図4】





# 【図7】









[図19]

pushn命令, popn命令のビットマップ。...

| 16    | 4 3 0 |     |    |     |       |
|-------|-------|-----|----|-----|-------|
| 00000 | 0 1 0 | 00  | 00 | %Rd | or%Rs |
|       |       |     |    |     |       |
| 命令    | 0     | р   |    |     |       |
| pushn | 0     | 0 0 |    |     |       |
| popn  | 0     | ľ   |    |     | ٠,    |

【図15】

call imm



## 【図16】

ret



[図17]

(A) push RI 文打時の動き



(B)

push R2 支行時の動き





【図21】

. pushnの動作フロナャート



【図22】



#### 【図23】



フロントページの続き

(72)発明者 佐藤 比佐夫

長野県諏訪市大和3丁目3番5号 セイコーエブソン株式会社内